Coder Social home page Coder Social logo

Comments (23)

DarrenJiang13 avatar DarrenJiang13 commented on August 15, 2024 5

Maybe we need to consider some compatibility to SDKs like jedis.

Like "cluster nodes", it may return with "master" field and might be used by some SDKs.

from valkey.

stockholmux avatar stockholmux commented on August 15, 2024 4

3 major version would be enough transition time, I'd assume.

But mainly I'm just advocating have a set plan before changes happen so it doesn't languish for an undetermined amount of time.

from valkey.

zuiderkwast avatar zuiderkwast commented on August 15, 2024 3

Yes, 1 and 2 can be done immediately IMO, but in two separate PRs.

from valkey.

PingXie avatar PingXie commented on August 15, 2024 2

I would vote for "primary" and "replica".

As for changes, I now think more and more that we need a "compat" knob. It can be either compile time or runtime (via config).

We could also consider a staged change:

  1. Anything non-user facing, i.e., comments, function/variable names, etc

  2. Aliasing input to support both terminologies (but also under the "compat" switch)

  3. Changing output. Aliasing would not work in this case. We will default to the new terminology but it can be overridden by the user, again either compile time or runtime (pending decision)

from valkey.

singlyfy avatar singlyfy commented on August 15, 2024 2

@alonohana627 May I ask why you down-voted this? Just curious. If it's about compatibility, I'd like to hear it so we can make a better decision.

all his (recently) created github repositories are using "master" for branch naming,
so I think it is personal preference in this case

from valkey.

GaryPWhite avatar GaryPWhite commented on August 15, 2024 2

@zuiderkwast , I have taken a look and don't really have time to dig into this and do it right. Other folks should feel free to pick this up :) sorry for whiplast!

from valkey.

zuiderkwast avatar zuiderkwast commented on August 15, 2024 1

Yes, the breaking change is a "major decision". We should analyze the implications a bit more too. There may be reasons to be compatible with other forks and implementations so we should also keep on eye on them.

We may even consider some possibility for conditional compilation or similar.

from valkey.

stockholmux avatar stockholmux commented on August 15, 2024 1

If there is a compat knob, it would be good to have a pre-determined sequence of deprecation.

E.g. version n introduce knob and optional new terminology, version n+1 new terminology becomes default, old terminology is deprecated, version n+2 remove old terminology.

Otherwise these things just linger. Pull off the bandaid, as they say.

from valkey.

hpatro avatar hpatro commented on August 15, 2024 1

de-crapify 😂

from valkey.

alonohana627 avatar alonohana627 commented on August 15, 2024 1

@singlyfy @zuiderkwast sry for downvote!!! I don't have an opinion, when I create a repo I don't consider the main's repo name. It was a missclick. I remove the downvote.

I want to contribute but I'm new, I'm not sure if upvote/downvote this suggestion because I sincerely don't understand it. I hope you won't think I tried to troll or anything, sorry for the inconvenient.

from valkey.

zuiderkwast avatar zuiderkwast commented on August 15, 2024 1

@Dom4n It is a very valid concern. I think backward compatibility is very important, especially in this kind of project which has been mostly feature-complete since many years. Let's think about it a bit more.

from valkey.

GaryPWhite avatar GaryPWhite commented on August 15, 2024 1

absolutely interested -- sorry for the delay. Felt like a lot happened at once -- I'll start taking a look!

from valkey.

GaryPWhite avatar GaryPWhite commented on August 15, 2024

Hi! Would this be a decent "first issue" for a techie who's interested in getting more involved with the alt/redis ecosystem? I'd be happy to use this as a way to get more familiar with the repo :)

from valkey.

zuiderkwast avatar zuiderkwast commented on August 15, 2024

@GaryPWhite Yes, that's great, but first we need to analyze and decide exactly what we need to do and in which steps. There are implications like Redis compatibility to consider.

from valkey.

zuiderkwast avatar zuiderkwast commented on August 15, 2024

@GaryPWhite Actually I think you can start with the non-breaking changes of simply adding PRIMARY aliases (or rather make MASTER an alias of PRIMARY) for these:

  • CLIENT KILL TYPE MASTER
  • CLIENT LIST TYPE MASTER
  • SENTINEL GET-MASTER-ADDR-BY-NAME

Look into how SLAVE is already an alias of REPLICA in these commands.

from valkey.

hwware avatar hwware commented on August 15, 2024

Agree with master as an alias of primary. But suggest to hold the master and slave name, maybe they will remove in future version

from valkey.

PingXie avatar PingXie commented on August 15, 2024

Pull off the bandaid, as they say

Yes we should do it at some point but I think the timing of it falls in another major decision and we need to give our users ample time to adjust. As much as I am personally in strong favor of ripping this bandaid off asap I also understand that the success of this project is very much dependent on "continuity". It takes time to turn this huge ship around.

from valkey.

PingXie avatar PingXie commented on August 15, 2024

I'm just advocating have a set plan before changes happen so it doesn't languish for an undetermined amount of time.

Timing aside, I think one option, as you suggested too, is to just remove this compat knob and we are done. I have yet to think of other options because as far as output is concerned, it is a binary decision. So the plan in my opinion is more about deliberating a timeline with the help of the community, than an engineering plan to help with a smooth transition. In other words, I think #36 (comment) is the best we can do. Curious to hear other folks' thoughts.

from valkey.

zuiderkwast avatar zuiderkwast commented on August 15, 2024

@alonohana627 May I ask why you down-voted this? Just curious. If it's about compatibility, I'd like to hear it so we can make a better decision.

from valkey.

Dom4n avatar Dom4n commented on August 15, 2024

I have down-voted only because I don't encourage making breaking changes, aliases are totally fine.
But please do not force name change by removing old naming conventions.

from valkey.

zuiderkwast avatar zuiderkwast commented on August 15, 2024

@GaryPWhite Are you still interesting in helping out with the non-breaking changes?

We will not do any of the breaking changes at this point.

from valkey.

robd003 avatar robd003 commented on August 15, 2024

There is zero logical reason to make a breaking name change like this. It's just going to cause issues with 3rd party tools.

Nothing of value will be gained by doing this.

from valkey.

madolson avatar madolson commented on August 15, 2024

There is zero logical reason to make a breaking name change like this

We're only making the non-breaking changes. Anything part of the API (the command names) or API responses will remain the same.

from valkey.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.