-
Notifications
You must be signed in to change notification settings - Fork 68
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
pterm conflicts with putty #1836
Comments
I should think one would install PRRTE (or putty) in some location (e.g., /usr/local/prrte) to avoid precisely such conflicts. As you can imagine, trying to come up with tool names that don't conflict with the tens of thousands of packages out there is an exercise in futility. I know one other package took exception to 🤷♂️ I don't have a solution to the global name problem short of putting packages in unique locations and letting the |
That's not relevant in the Linux distribution context where everything gets installed into |
Given that it's been out there for at least five years and embedded into people's job scripts, yes - it would be a fairly disruptive change and hardly seems worth it. IIRC, you can "conflict" the I gather you are encountering the problem due to creating packages for the embedded code in OMPI? How do you handle the conflicts between |
That's not really a solution, because users generally want to refer to a binary by name and not the full path. So placing a binary somewhere not in
It is a "solution", but a really bad one. It is totally legitimate to want to have both installed at the same time. And also, there often are big dependency chains which means that users get various packages which they don't necessarilly "need". "Conflicts" between packages are painful to users.
MPI packages do not provide any binaries in the normal If you want to do right by users, my strong recommendation would be to take the unpleasant step of renaming the binary. (Provide a compat symlink for a time being to make the transition easier.) This is better than the confusion for users which binary they'll be running. |
PRRTE is being installed here to support OMPI. I fail to understand all the kerfluffle - your MPI solution is totally appropriate for PRRTE. OMPI uses PRRTE to provide
I don't see how causing problems for one set of users at the benefit of others constitutes "doing right by users". It seems like you are making an inherent value judgment about which users should be disturbed.
Doesn't that just recreate the conflict? If you can tolerate the symlink, then why not the binary itself? It seems odd that you have a solution you consider perfectly acceptable for one set of packages (MPI), but somehow is unacceptable for all others. Just treat PRRTE like you do MPI, especially since you are installing it to support a particular MPI package. Maybe I'm just missing it, but I fail to understand why the reluctance to use a solution you already consider standard practice? |
Installing two binaries with the same name (putty Also, I doubt that there are many applications that use |
I guess that we need to revise all the MPI's then, too - yes? That is precisely their situation. Why is PRRTE (and putty, for that matter) being treated differently? Look, if people feel this is such an insurmountable problem and just cannot use the standard solution, then don't install PRRTE. I assure you I will not take offense. Those that want to use it know how to get it and do so. Just use the embedded version for your OMPI distro and be done with it. |
There is no
The case of two unrelated programs is different. |
I think people are talking a bit at cross purposes here and not being particularly constructive - so maybe just let it lie for a bit. I think it probably does make sense for Fedora to move the prrte binaries into Thanks, and sorry for any antagonism. |
Thanks @opoplawski - I agree that the discussion is getting derailed. No antagonism inferred. It is true there is nothing OMPI-specific about PRRTE itself (i.e. PRRTE does not depend on OMPI). PRRTE can support any PMIx-based application, and people from MPICH, OpenSHMEM, and others use it. However, that is in many ways a separate discussion. For now, those people (or their sys admins) download and install PRRTE directly, almost always creating a In the context here, if you are trying to package it as a part of the OMPI dependencies, then it (IMO) makes sense to put it in the OMPI install location. OMPI is a little complicated now in that it doesn't have a direct dependency on PRRTE, but does use PRRTE to provide its version of |
FWIW: In terms of who uses PRRTE and for what types of apps, I always forget that PBSPro includes PRRTE in its distribution (at least, last I heard - few months old, but likely still true). PRRTE serves as their general application launcher within the PBS allocation, and is automatically started when an allocation is made. I don't know the details of their distribution (e.g., where PRRTE is installed). The only user-level cmd that they need to expose is I have no idea how they would adjust (or not) to a Fedora PRRTE package, how they are adjusting (or not) to OMPI v5 including an embedded version of PRRTE, etc. |
Adding @amckinstry since he has similar question. Some thoughts about packaging PMIx and PRRTE: I would strongly advise against installing PMIx into a default location (I will use "/usr/local" just as an example). Starting in the PMIx v4.2 series, PMIx automatically installs all of its internal headers so that PRRTE can reuse the code - and I doubt you want that rather large tree of headers hanging under "/usr/local/include". This allowed us to remove over 10,000 lines of redundant code from PRRTE, greatly reducing the maintenance burden. The negative to that, however, is that PRRTE is now tightly coupled to PMIx, and so the two will almost always need to be updated together. It may therefore be beneficial to install PMIx into a "/usr/local/pmix-version" location to allow multiple versions to coexist (ditto for PRRTE). This raises an issue in PRRTE that still needs to be addressed. Currently, PRRTE enforces a minimum PMIx level that it can build against. This is probably not sufficient as changes in a PMIx utility (not part of the official API) could result in a behavioral change that impacts PRRTE's use of that utility. It isn't possible to define a "max PMIx version" for PRRTE as no one can predict when such a change might occur, so it may be that we have to "lock" each PRRTE release to a specific PMIx one. We may also need to runtime check the version (which PMIx supports) to ensure that we are running against a compatible PMIx version since that could be different than the one we built against. All still under consideration. OMPI updates are likely to include updates to PMIx and PRRTE, but that isn't a requirement and will almost certainly not be universally true. OMPI does have a min PMIx version requirement, and I believe they added one for PRRTE just to ensure that the So the bottom line is that you have three software projects, two of which are tightly coupled and almost certainly need to be in sync. All three technically have independent release cycles, though in reality PMIx and PRRTE will almost certainly be coordinated. I think it is fair to say that the PMIx and OMPI communities are still trying to work all this out. Hope that helps. |
There is a developing practice in Debian of installing conflicting variants of something in prefix=$LIBDIR/xx/yy/ |
Sounds reasonable to me. If someone installs multiple variants, you might need some thought about how to connect OMPI to one of them based on dependencies - i.e., which variant(s) a particular OMPI release can use. We are looking at using some "capability flags" in each package to support runtime checks so we can error out with a helpful message if the wrong combination is in use. |
Hi, regular linux user here, I had never had nor needed to use prrte package until I was doing a system upgrade today and prrte was being installed as a dependency for openmpi package for which is a dependency for other stuff. Anyway I got the dependency issue in package manager related to having putty installed which I actually use and I don't need prrte itself except some of my other package require it, so I have to agree with the people above saying this does affect other users and is not convenient as I can't use putty now without going around the package manager. |
+1 |
@rhc54 You have indicated reluctance to rename |
I'd have to think about it. To me, this is a packager issue - a packager can do whatever they want with the naming, can install things into non-conflicting locations, etc. In fact, they can even choose not to install Which is why I find the discussion so confusing/frustrating. I get that packagers are only now starting to package PRRTE, and that's due to the OMPI folks adoption of it. However, there are quite a few installations of it out there that were not installed via package. Disrupting them when the packagers have several tools to avoid their situation seems somewhat odd to me. If there were no other solution, then I'd be more amenable to it. But there are several available at the packager level - just having trouble understanding why they refuse to use their own tools to solve it. To answer your related question, |
Here's a simple solution: put the path to |
Sorry, but I doesn't catched the idea? Pls. one more detail.... |
@bronkoo I think he means: PATH='/path/to/putty/bin:/path/to/prrte/bin' I may be missing something here, but I don't think this is how packaging works. Packages don't have separate bin directories that are installed on the path, nor do they affect a user's PATH variable. |
Thanks, but therefore I doesn't understood it... |
This will not "fix" the packaging problem. To quote #1836 (comment):
But since I think we will go with renaming |
You should never put PRRTE in a standard location, just like you don't put One packager above noted that Debian has gone this route for exactly this reason. |
You are entirely free to do so - please rename the package to something other than PRRTE, though, to avoid confusing everyone else.
I think I've concluded that I won't be changing it. There are simply too many easy solutions you have at your fingertips that do not require impacting everyone else - there is no reason to inconvenience those who have been working with PRRTE for the last seven years. |
Yes, I agree - but that is what |
Ah, ok... misunderstood it. But I'm looking at it here from my desktop's perspective... Regarding my HPC Cluster I'm fine with the |
Why do we see this "our software is special and has to be treated special! Screw integration!" attitude so often? |
I don't think anyone is expressing that attitude. Just the opposite, really. I'm pushing for you to properly integrate things instead of trying to force uniformity across a very wide community. This keeps appearing because there are so many conflicting packages out there - which is why tools for dealing with it were developed and are so commonly used. Better question is: why is the packaging community having such difficulty adjusting to the evolving situation? Some packagers seem to be adopting, so it isn't impossible. But change is always unsettling and takes time. |
I think the commentary is turning a tad pithy again, and we seem to have wrung as much out of this as we can - so I'll just close this now. |
I'd like to add something to this, if I may. My intention is not to resurrect a contentious discussion. (I agree the conversation was going nowhere up to the point @rhc54 reasonably decided to end it.) Rather, I'd like to propose an outside-the-box, long-term approach to sorting this out. It won't really help with the immediate problem, but it would mean that, eventually, it goes away for good. The PRRTE install includes five binaries that end up in the
Of those five, obviously But couldn't the other four all be subcommands of the single
If the tools were consolidated that way, after a deprecation period the separate binaries could be removed from the installation, and the conflicts would cease to exist. It'd be a slow solution, but ultimately a complete one. And arguably, one that makes the toolset more unified and discoverable as a side benefit. (If the binaries are installed to |
Hmmm...well, that's the most reasonable alternative someone has put forward - thanks! Let me ponder it a bit. The OMPI folks are reusing Barring that, my initial inclination would be to go with it, or at least something close. I don't think anyone was expecting to see |
So if it's called with what would become the "legacy" semantics (i.e. the ones it has right now -- no subcommand, and flags appropriate for |
Agreed. I would have to modify your proposal a bit to make it work with the Will ponder and play a bit. Probably going to be the fall before anything really happens as my time is rather limited and my "to-do" list has a few things already on it. |
Will leave this open so I see it later in the year as a reminder. |
Well, I took a different slant on it as my initial thoughts proved far more difficult to implement than it was worth. Messing with cmd line options wreaked havoc with the "--help" option and other similar features. So what I've done is:
So if you don't like/want the current names, you can disable the legacy tools at configure time and you'll be left with only the new names. Otherwise, you'll have both names, just with symlinks connecting old to new. Best I can do, I'm afraid, without major code changes. I thought about displaying a deprecation message when someone uses the current command name, but that would be rather disruptive to current users. We can see if this proves sufficient. |
Background information
It has been discovered that both prrte and putty provide a /usr/bin/pterm executable - which is problematic if a user wants both installed.
Any suggestions for dealing with this? Pretty sure putty's pre-dates prrte's by about 18 years.
What version of the PMIx Reference RTE (PRRTE) are you using? (e.g., v2.0, v3.0, git master @ hash, etc.)
3.0.2
The text was updated successfully, but these errors were encountered: