I nearly spat my coffee out when I read that it was to be replaced by "leader/follower". That would be a bad idea, IMO, and what most people here and on the Github thread are commenting on.
But actually, the terminology being used is primary/replica, which is if anything more descriptive.
Is it, really? Please elaborate why it would be more descriptive.
I think this is a nonsense change and just the fact that they did this change without hesitation makes me question if Django is a good choice for future projects.
You can't make changes to established naming without consequences, what about classes? Don't they offend people who does not come from money? Django is full of them, dividing stuff into different classes. That is just disgusting. They must stop to use classes now!
I would have no objection if they changed to primary/replica for a good reason, but this is a shit reason.
From my point of view, its a pretty bad idea.
Master / Slave is used in nearly every system ranging from basic integrated circuits using a bus (SPI, I2C, ...) up to multi cluster database systems.
It has a clearly defined function and and everyone in tech knows what it means. It doesnt matter if youre from USA, England, Germany oder Iran. A master/slave system has a clearly defined behavior.
Trying to bring feelings into the clean technical world it one of the most stupid things i can think of.
In this case, it only affects the documentation of a project, but in other cases, trying to be politically correct has destroyed lifes of people.
http://www.wired.com/2013/03/richards-affair-and-misogyny-in...
.... this is simply lame, the master/slave term describes perfectly fine the relationship between the parts, and leader/follower is a bit more vague, since a follower is during it voluntarily, while the slave adheres to the masters rules... At least how I see it.
Leader/follower isn't what they went with; as noted elsewhere, they used primary/replica instead.
Master/slave also doesn't accurately describe it beyond a very superficial level, and its historical usage doesn't make it any more apt. In distributed systems, the primary does not sit back while forcibly delegating all its productivity.
I think this is an awesome patch. Hopefully more people will follow suit. The first time someone was trying to describe a configuration using 'master' and 'slave' to me, the terminology was really distracting, and I could barely pay attention without remembering all of the lessons about U.S. history from 8th grade. I hope this change in terminology will help make software development more welcoming and accessible to more people.
A big difference is that there is consensus that slavery is altogether a bad idea (at least among the people using the term master/slave in the current context), while there is no such consensus concerning sex.
At first I thought this commit was a joke, then I felt a slight annoyance at this political correctness, only to finally realize that it's not really such a bad idea, since we all agree slavery is bad, and it can be quite awkward to use the terminology around people that don't hear it often.
If we don't want our jargon to sound awkward to laymen, we've got to replace a lot more words than master and slave.
Industry terms are valuable, though, aren't they? They allow expressing complex concepts unambiguously, and can be expected to be used consistently across given field. Personally I think that trying to control jargon and have it conform ever-changing politics and common language is detrimental to the industry and hinders knowledge transfer.
I suspect (or hope) it's just trolling on the part of Alex.
(Disclaimer: English is not my native language, I wonder if saw this differently if it were.)
My point wasn't that it's awkward primarily. I agree with you that the whole point of jargon is for 'insiders' to be able to communicate quickly and unambiguously.
The point is that it could be sensitive and just isn't a nice term to use day to day. I've had moments myself where using the master and slave terms felt a bit... odd. It very well might be that I was the only one feeling a bit awkward, but that itself is a reason to consider using less loaded terms.
Second, though I agree that industry terms are valuable, I can't think of that many terms that have connotations similar to slavery (but by all means jog my memory!). And even if there are, I don't see why we can't incrementally change our terminology and phase out anachronistic (and/or loaded) ones.
Finally though, I don't find this a big issue. I see it as relatively easy to slowly change this term, and I like that, but I don't feel like I should actively argue for changing the terms 'master' and 'slave'. But I do enjoy discussing it :).
You're right—I can't think of any more terms that have connotations of comparable negativity (though quite a few plainly odd-sounding ones). I will blame my indifference to this question on my English non-nativity. :)
The only remaining argument against the change is searchability—hopefully Google knows or will learn soon that these are interchangeable terms.
That's a good point. Google has been doing a decent job at that so far, though, and I suspect if such a change in terminology were ever to become mainstream, it will be a gradual process, and generally specific to 'newer' systems.
Good call. "Leader" and "follower" may not be the most precise, descriptive terms here, but then neither were "master"/"slave" and people got used to that.
Edit: "Primary"/"replica" seems like an unambiguous improvement.
If you're going to replace a term, it might be a good idea to pick a new one which is precise and descriptive, given the opportunity to do so.
"Senior" and "junior" might work, or "primary" and "secondary". It might be important to capture not just the fact that authority resides with one server and not the other, but that the secondary server is effectively forced to obey via configuration, to distinguish from clusters whereby leaders may be elected, and so on.
Using any anthropomorphic terms at all may end up being misleading - Dijkstra was pretty down on anthropomorphism[1] because he believed that it was a cause of confusion and error. However, if we're going to use anthropomorphic terms then I think it's unwise to choose them based on whether or not those terms, in entirely different circumstances, may have been related to unfairness and harm. The whole point about why slavery is bad is that it involves treating a person like a machine, but this clearly implies that treating machines in such a way is obviously not wrong. Words generally aren't fnords[2] that cause us to become irrationally upset at merely seeing the word itself in print.
"Master/slave is a model of communication where one device or process has unidirectional control over one or more other devices. In some systems a master is elected from a group of eligible devices, with the other devices acting in the role of slaves."[0]
I'd say that master/slave describes perfectly well the relationship between the parts.
it looks like primary/replica and master but not slave. Master is used in the documentation and was probably incorrectly or hastily replaced with leader.
I was thinking parent/child would be a better fit, but upon further thinking about it, leader/follower is pretty good. It is also a bit more distributed friendly, in that you can follow a new leader or switch. Where parent/child, master/slave are more locked. It is a bit silly though to change, in that human history has had slavery throughout history and to this day. Better to know about the problems than to overlook them. Also, throughout history, slavery wasn't always on racial lines, it was usually class based or wealth/monarchy based.
- Master / Slave systems are typically locked in. One slave if a database system can only be a copy of one master and cant just switch freely between masters.
- Leader / Follower is coupled to loosely in my opinion. When i hear leader / follower i'm more thinking of a system where the followers follow the state of the leader (e.g. if the database goes down, the web frontend is shutting down / displaying an static error / ...)
[sarcasm]
- Parent/child could be offensive to people who cannot have kids or whose kids have died! Have you thought about THEIR feelings aswell?
[/sarcasm]
I always thought the use of master/slave terminology on ide hard drives was amusing because of the s&m connotations, but then I was a bit of a weird kid. I guess that is one of the few instances where thinking about s&m is the more innocent option. Leader/follower is not a bad change, it is perfectly understandable for people used to the existing terminology and has less distracting connotations.
Choosing not to use the term doesn't mean it reminds people of slavery, it simply means that they choose not to perpetuate a term with negative connotations when an alternative term without them suffices.
Have you ever taught African-American kids about database replication? I'm guessing "no", because the master/slave terminology actively interferes with the learning environment — more so than adopting this less common terminology would.
To elaborate, slavery has existed in many times and places and still exists in some places today. Many people have to live with the fear of slavery even now.
In that aspect, I don't think leader/follower conveys any more information than the former terms either. It seems like this just opens up a whole lot of StackOverflow question on "Is there any difference between master/slave architecture and leader/follower one".
Primary/Secondary aka Master/Slave already happened with DNS... e.g. http://www.zytrax.com/books/dns/ch4/ and since you can have Master-Master relationships in databases as well as "equal" relationships where two masters can each be slaves to the other for redundancy... it's messed up however you look at it.
Personally I prefer Primary & Secondary but I'll use the language the manual uses for whatever product I'm configuring, since it makes life easier.
In that page, it doesn't describe it as political correctness run amok. Those cases are reserved for the correct usage of a word that merely resembles some inappropriate term.
Master/Slave as a relationship originated before computers and refers to possessing another person as property, so it's negative connotations are inherent in the phrase and rejecting them is a linguistic choice.
Contrast that to using the phrase retarded in Physics, which originally was just a term used to describe a time delay, and was ultimately applied to people who had delayed development, and is now considered inappropriate, though it is still used in physics from time to time.
> Master/Slave as a relationship originated before computers and refers to possessing another person as property
Yes, and slavery is any form is heinous. But if we're talking about terminology... master and slave terms in computing have become to describe a certain kind of logical topography. For me, a term being somehow inappropriate is not alone enough to warrant finding euphemisms.
There are terms like that all over the place. Your example, "retard" is used at least in cooking to describe a component inhibiting a desired process. I wouldn't be surprised if someone found bridge building to be inappropriate ("erection sequence"), and people in corporate security business are doing pen-testing all the time.
There is something in the need for euphemisms that rubs me the wrong way. It depletes a language and nibbles its users of variety.
Come to think of it - one of Agatha Christie's novels was renamed twice due to insensitivities. The current name is, I believe, "And then there were none".
I for one would prefer dom/sub, if we're going to go about rewriting perfectly good terminology that has been around for near a hundred years, but I don't think people are quite that open-minded yet (even though it helps remove the troubling idea of property rights on sentient beings).
Naming is hard!
Master/slave implies that there may be many slaves for one master, that the master tells the slave exactly what to do, and that slaves will not switch between masters on a whim.
Leader/follower implies that there is no major difference between the two classes and that perhaps the "leader" is just a promoted follower ("leader election", etc.), that the leader is the first to hit a request or command, and that the followers may spontaneously decide to follow a different leader.
Primary/secondary implies that the roles are equivalent, that requests are handled by the primaries, that there may be more than one instance of each role, and that secondaries are only used if a primary cannot deal with its task.
Note that each use case is equally valid: m/s could be a read/write architecture for a database or electrical communications bus, l/f for a distributed simulation system spanning many nodes or a swarm of agents, and p/s for a redundant storage system.
But, changing nomenclature seemingly for the hell of it is not usually a good idea.
But actually, the terminology being used is primary/replica, which is if anything more descriptive.