Why doesn't root alias vi to vim if it's standard for other users?

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
0
down vote

favorite












On centos (and I believe many other distros) vi is aliased to vim for all users by default. However, for whatever reason vi is not aliased to vim for the root user, something that always annoys me when I forget to type vim instead of vi when using sudo and don't have vim features I've come to take for granted, like default syntax highlighting.



I understand how the aliasing is done, and programmatically why an alias doesn't exist when I sudo/su. I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?



Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)










share|improve this question

















  • 1




    We always setup such an alias here, more convenient.
    – Rui F Ribeiro
    Sep 13 at 14:31











  • I always type vim when I want vim as it's not vi on all the systems I use. Actually I compile a custom vim on RedHat for a usable version without all the colours and other such vendor crud...
    – thrig
    Sep 13 at 15:36














up vote
0
down vote

favorite












On centos (and I believe many other distros) vi is aliased to vim for all users by default. However, for whatever reason vi is not aliased to vim for the root user, something that always annoys me when I forget to type vim instead of vi when using sudo and don't have vim features I've come to take for granted, like default syntax highlighting.



I understand how the aliasing is done, and programmatically why an alias doesn't exist when I sudo/su. I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?



Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)










share|improve this question

















  • 1




    We always setup such an alias here, more convenient.
    – Rui F Ribeiro
    Sep 13 at 14:31











  • I always type vim when I want vim as it's not vi on all the systems I use. Actually I compile a custom vim on RedHat for a usable version without all the colours and other such vendor crud...
    – thrig
    Sep 13 at 15:36












up vote
0
down vote

favorite









up vote
0
down vote

favorite











On centos (and I believe many other distros) vi is aliased to vim for all users by default. However, for whatever reason vi is not aliased to vim for the root user, something that always annoys me when I forget to type vim instead of vi when using sudo and don't have vim features I've come to take for granted, like default syntax highlighting.



I understand how the aliasing is done, and programmatically why an alias doesn't exist when I sudo/su. I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?



Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)










share|improve this question













On centos (and I believe many other distros) vi is aliased to vim for all users by default. However, for whatever reason vi is not aliased to vim for the root user, something that always annoys me when I forget to type vim instead of vi when using sudo and don't have vim features I've come to take for granted, like default syntax highlighting.



I understand how the aliasing is done, and programmatically why an alias doesn't exist when I sudo/su. I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?



Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)







centos vim root alias vi






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Sep 13 at 14:08









dsollen

376215




376215







  • 1




    We always setup such an alias here, more convenient.
    – Rui F Ribeiro
    Sep 13 at 14:31











  • I always type vim when I want vim as it's not vi on all the systems I use. Actually I compile a custom vim on RedHat for a usable version without all the colours and other such vendor crud...
    – thrig
    Sep 13 at 15:36












  • 1




    We always setup such an alias here, more convenient.
    – Rui F Ribeiro
    Sep 13 at 14:31











  • I always type vim when I want vim as it's not vi on all the systems I use. Actually I compile a custom vim on RedHat for a usable version without all the colours and other such vendor crud...
    – thrig
    Sep 13 at 15:36







1




1




We always setup such an alias here, more convenient.
– Rui F Ribeiro
Sep 13 at 14:31





We always setup such an alias here, more convenient.
– Rui F Ribeiro
Sep 13 at 14:31













I always type vim when I want vim as it's not vi on all the systems I use. Actually I compile a custom vim on RedHat for a usable version without all the colours and other such vendor crud...
– thrig
Sep 13 at 15:36




I always type vim when I want vim as it's not vi on all the systems I use. Actually I compile a custom vim on RedHat for a usable version without all the colours and other such vendor crud...
– thrig
Sep 13 at 15:36










3 Answers
3






active

oldest

votes

















up vote
1
down vote



accepted











I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?




if you notice for root versus users on echo $PATH you will see a much shortened list... by default



It is basically a security mentality for a default security posture for linux out of the box... for those people who wish to just install and go and expect everything to be set up with regards to security.




Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)




for the most part, no there is no harm adding aliases to be available for the root account. Just be mindful of how and where you do it. The security mentality assumes something like this may happen and that would be an attack vector and one of many means to hack a system. Security mindset = minimize or prevent any/all attack methods hence no aliases.



fwiw, I use SLES and have used RHEL. I prefer to edit /etc/bash.bashrc.local and /etc/csh.cshrc.local to add my aliases, this works for non-privileged users. And these two files are owned by root.rootwith permissions -rw-r--r--. For root, I simply edit /root/.bashrc.



aliases do not circumvent basic security policies, if they do then the problem is not with the alias it's with something else.






share|improve this answer




















  • you also asked if it's desirable behavior. From one perspective (i.e. security) yes. From my perspective it is undesireable because when I type vi I want vi not vim so I go the extra step qnd edit wherever default aliases exist in the system files... which you are not supposed to edit.
    – ron
    Sep 13 at 15:03


















up vote
1
down vote













This question is verging on soliciting personal opinion. An administrator is allowed to set up their system in such a way that it suits them, and if the default setup is annoying you I would suggest that you change it.



However...



The root user is not an ordinary user, and every action taken at the interactive prompt while logged in as root should ideally be carefully considered. To remind an admin that they are logged in as root, the root prompt in most shells are by default different from the default prompt for privileged users, and indeed, working at a root prompt should remind you that you actually shouldn't be there for very long, if at all1.



One reason vi is not aliased to vim might me that in a situation where shared libraries have gone AWOL (due to a disk failure or accidental deletion), vi may be a static executable that would work anyway (or it may be linked with libraries from another path), allowing the administrator to edit files to get the rest of the system up and running again.



The same reasoning can be applied to other "bells and whistles" that ordinary users may enjoy. In situations where an admin may be forced to bring up an interactive root shell, the dependencies of the extra features may simply not be available.




1Working at a root prompt, you have no audit trail of the commands that you have typed. It is therefore better to use facilities such as sudo to do root-related tasks since sudo by default logs who does what when. This is extra important on systems where more than one person has admin rights and on corporate systems.






share|improve this answer


















  • 2




    vi (and the standard editor, ed) is dynamically linked on Centos 7 so if you screw up libc.so you probably need some other plan
    – thrig
    Sep 13 at 14:51










  • @thrig Yes, and it may well be a "tiny" vim. It should at least be linked to fewer libraries. Hmm...
    – Kusalananda
    Sep 13 at 15:01

















up vote
1
down vote













Decisions like this usually hinge upon catering to concerns about ease of maintenance and safety, albeit that security, mentioned in other answers, is a factor. Some system administrators don't want odd undocumented personal customizations for the superuser's interactive environment. They want things to behave in the standard, documented, ways; with no nasty surprises. They moreover want to avoid having to re-apply personal customizations after fresh installations, system upgrades, and so forth.



In the case of vi, aliasing it to vim potentially brings up a different program on CentOS, /usr/bin/vim instead of /bin/vi. The former is an optional "enhanced VIM" that could be present, with all sorts of features compiled in, whereas the latter is "tiny VIM" with very few optional features enabled. (Ubuntu has a similar idea.) People generally want the vi command to behave as the standard vi command, especially when doing stuff as the superuser. They don't want some enhanced whiz-bang feature or plug-in altering stuff in surprising ways; or, worse, breaking in rescue or emergency modes. They don't want all of the vi reference doco that someone doing critical work as the superuser consults, to be drastically erroneous because of such things.



This means invoking vi when the adminstrator asks for vi, not vim.



Put another way: Whereas you have come to take all sorts of VIM customizations and extensions for granted, what some other people tend to take for granted is that the superuser account does not have such customizations and extensions. They build that assumption into WWW pages, Q&A answers, and books that they write. They form habits and carry knowledge from one system to the next of what they'll get when the superuser runs vi. (And sometimes this is that it has VIMisms, ironically. One of the things that people have to learn going from a Linux operating system to FreeBSD is that vi is nvi and not any flavour of VIM at all.)



Moreover: They want not to have to remember to carry /root/.vimrc and /root/.gvimrc over hard disc changes, system reinstallations, and the like; in addition to the system-wide configuration files.



Another example of this thinking in action is the toor account on FreeBSD. It's the superuser, but with a Bourne-like shell (the Almquist shell, in fact). The root account has the TENEX C shell, and because there are decades-worth of BSD doco that show the superuser driving the system with the C shell, advice that people give is to leave that as it is, and use toor for Bourne-like interaction. The C shell is the expected environment when logging in as root, and if it came up with a Bourne-like shell for a superuser who had (say) a book of C shell instructions for administering FreeBSD, hilarity and indeed potentially disaster would ensue.



Further reading



  • "vi". Shell and Utilities. Single UNIX Specification. Issue 7. IEEE 1003.1. 2018. The Open Group.

  • https://askubuntu.com/questions/281886/

  • Dru Lavigne (February 2009). BSD Hacks: 100 Industrial Tip & Tools. O'Reilly Media. ISBN 9780596006792.

  • https://unix.stackexchange.com/a/397056/5132

  • Sven Guckes (2017). Vi Clones and HomePages. guckes.net.





share|improve this answer




















    Your Answer







    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "106"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    convertImagesToLinks: false,
    noModals: false,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













     

    draft saved


    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f468804%2fwhy-doesnt-root-alias-vi-to-vim-if-its-standard-for-other-users%23new-answer', 'question_page');

    );

    Post as a guest






























    3 Answers
    3






    active

    oldest

    votes








    3 Answers
    3






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    1
    down vote



    accepted











    I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?




    if you notice for root versus users on echo $PATH you will see a much shortened list... by default



    It is basically a security mentality for a default security posture for linux out of the box... for those people who wish to just install and go and expect everything to be set up with regards to security.




    Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)




    for the most part, no there is no harm adding aliases to be available for the root account. Just be mindful of how and where you do it. The security mentality assumes something like this may happen and that would be an attack vector and one of many means to hack a system. Security mindset = minimize or prevent any/all attack methods hence no aliases.



    fwiw, I use SLES and have used RHEL. I prefer to edit /etc/bash.bashrc.local and /etc/csh.cshrc.local to add my aliases, this works for non-privileged users. And these two files are owned by root.rootwith permissions -rw-r--r--. For root, I simply edit /root/.bashrc.



    aliases do not circumvent basic security policies, if they do then the problem is not with the alias it's with something else.






    share|improve this answer




















    • you also asked if it's desirable behavior. From one perspective (i.e. security) yes. From my perspective it is undesireable because when I type vi I want vi not vim so I go the extra step qnd edit wherever default aliases exist in the system files... which you are not supposed to edit.
      – ron
      Sep 13 at 15:03















    up vote
    1
    down vote



    accepted











    I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?




    if you notice for root versus users on echo $PATH you will see a much shortened list... by default



    It is basically a security mentality for a default security posture for linux out of the box... for those people who wish to just install and go and expect everything to be set up with regards to security.




    Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)




    for the most part, no there is no harm adding aliases to be available for the root account. Just be mindful of how and where you do it. The security mentality assumes something like this may happen and that would be an attack vector and one of many means to hack a system. Security mindset = minimize or prevent any/all attack methods hence no aliases.



    fwiw, I use SLES and have used RHEL. I prefer to edit /etc/bash.bashrc.local and /etc/csh.cshrc.local to add my aliases, this works for non-privileged users. And these two files are owned by root.rootwith permissions -rw-r--r--. For root, I simply edit /root/.bashrc.



    aliases do not circumvent basic security policies, if they do then the problem is not with the alias it's with something else.






    share|improve this answer




















    • you also asked if it's desirable behavior. From one perspective (i.e. security) yes. From my perspective it is undesireable because when I type vi I want vi not vim so I go the extra step qnd edit wherever default aliases exist in the system files... which you are not supposed to edit.
      – ron
      Sep 13 at 15:03













    up vote
    1
    down vote



    accepted







    up vote
    1
    down vote



    accepted







    I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?




    if you notice for root versus users on echo $PATH you will see a much shortened list... by default



    It is basically a security mentality for a default security posture for linux out of the box... for those people who wish to just install and go and expect everything to be set up with regards to security.




    Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)




    for the most part, no there is no harm adding aliases to be available for the root account. Just be mindful of how and where you do it. The security mentality assumes something like this may happen and that would be an attack vector and one of many means to hack a system. Security mindset = minimize or prevent any/all attack methods hence no aliases.



    fwiw, I use SLES and have used RHEL. I prefer to edit /etc/bash.bashrc.local and /etc/csh.cshrc.local to add my aliases, this works for non-privileged users. And these two files are owned by root.rootwith permissions -rw-r--r--. For root, I simply edit /root/.bashrc.



    aliases do not circumvent basic security policies, if they do then the problem is not with the alias it's with something else.






    share|improve this answer













    I'm asking if there is a reason for this to be desirable behavior, ie why didn't the centos developers add an alias for root as well? Is there some sort of security or functionality issue with aliasing to vim for root users that doesn't exist for regular users? Is there a historical reason root alone should not have this alias?




    if you notice for root versus users on echo $PATH you will see a much shortened list... by default



    It is basically a security mentality for a default security posture for linux out of the box... for those people who wish to just install and go and expect everything to be set up with regards to security.




    Going along with that is there any harm in my adding a default alias of vi to vim for the root users on servers I maintain? And if I was to do it is there a preferable method I should use to go about it (or more accurately any method I should avoid using for security reasons?)




    for the most part, no there is no harm adding aliases to be available for the root account. Just be mindful of how and where you do it. The security mentality assumes something like this may happen and that would be an attack vector and one of many means to hack a system. Security mindset = minimize or prevent any/all attack methods hence no aliases.



    fwiw, I use SLES and have used RHEL. I prefer to edit /etc/bash.bashrc.local and /etc/csh.cshrc.local to add my aliases, this works for non-privileged users. And these two files are owned by root.rootwith permissions -rw-r--r--. For root, I simply edit /root/.bashrc.



    aliases do not circumvent basic security policies, if they do then the problem is not with the alias it's with something else.







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered Sep 13 at 14:58









    ron

    8131614




    8131614











    • you also asked if it's desirable behavior. From one perspective (i.e. security) yes. From my perspective it is undesireable because when I type vi I want vi not vim so I go the extra step qnd edit wherever default aliases exist in the system files... which you are not supposed to edit.
      – ron
      Sep 13 at 15:03

















    • you also asked if it's desirable behavior. From one perspective (i.e. security) yes. From my perspective it is undesireable because when I type vi I want vi not vim so I go the extra step qnd edit wherever default aliases exist in the system files... which you are not supposed to edit.
      – ron
      Sep 13 at 15:03
















    you also asked if it's desirable behavior. From one perspective (i.e. security) yes. From my perspective it is undesireable because when I type vi I want vi not vim so I go the extra step qnd edit wherever default aliases exist in the system files... which you are not supposed to edit.
    – ron
    Sep 13 at 15:03





    you also asked if it's desirable behavior. From one perspective (i.e. security) yes. From my perspective it is undesireable because when I type vi I want vi not vim so I go the extra step qnd edit wherever default aliases exist in the system files... which you are not supposed to edit.
    – ron
    Sep 13 at 15:03













    up vote
    1
    down vote













    This question is verging on soliciting personal opinion. An administrator is allowed to set up their system in such a way that it suits them, and if the default setup is annoying you I would suggest that you change it.



    However...



    The root user is not an ordinary user, and every action taken at the interactive prompt while logged in as root should ideally be carefully considered. To remind an admin that they are logged in as root, the root prompt in most shells are by default different from the default prompt for privileged users, and indeed, working at a root prompt should remind you that you actually shouldn't be there for very long, if at all1.



    One reason vi is not aliased to vim might me that in a situation where shared libraries have gone AWOL (due to a disk failure or accidental deletion), vi may be a static executable that would work anyway (or it may be linked with libraries from another path), allowing the administrator to edit files to get the rest of the system up and running again.



    The same reasoning can be applied to other "bells and whistles" that ordinary users may enjoy. In situations where an admin may be forced to bring up an interactive root shell, the dependencies of the extra features may simply not be available.




    1Working at a root prompt, you have no audit trail of the commands that you have typed. It is therefore better to use facilities such as sudo to do root-related tasks since sudo by default logs who does what when. This is extra important on systems where more than one person has admin rights and on corporate systems.






    share|improve this answer


















    • 2




      vi (and the standard editor, ed) is dynamically linked on Centos 7 so if you screw up libc.so you probably need some other plan
      – thrig
      Sep 13 at 14:51










    • @thrig Yes, and it may well be a "tiny" vim. It should at least be linked to fewer libraries. Hmm...
      – Kusalananda
      Sep 13 at 15:01














    up vote
    1
    down vote













    This question is verging on soliciting personal opinion. An administrator is allowed to set up their system in such a way that it suits them, and if the default setup is annoying you I would suggest that you change it.



    However...



    The root user is not an ordinary user, and every action taken at the interactive prompt while logged in as root should ideally be carefully considered. To remind an admin that they are logged in as root, the root prompt in most shells are by default different from the default prompt for privileged users, and indeed, working at a root prompt should remind you that you actually shouldn't be there for very long, if at all1.



    One reason vi is not aliased to vim might me that in a situation where shared libraries have gone AWOL (due to a disk failure or accidental deletion), vi may be a static executable that would work anyway (or it may be linked with libraries from another path), allowing the administrator to edit files to get the rest of the system up and running again.



    The same reasoning can be applied to other "bells and whistles" that ordinary users may enjoy. In situations where an admin may be forced to bring up an interactive root shell, the dependencies of the extra features may simply not be available.




    1Working at a root prompt, you have no audit trail of the commands that you have typed. It is therefore better to use facilities such as sudo to do root-related tasks since sudo by default logs who does what when. This is extra important on systems where more than one person has admin rights and on corporate systems.






    share|improve this answer


















    • 2




      vi (and the standard editor, ed) is dynamically linked on Centos 7 so if you screw up libc.so you probably need some other plan
      – thrig
      Sep 13 at 14:51










    • @thrig Yes, and it may well be a "tiny" vim. It should at least be linked to fewer libraries. Hmm...
      – Kusalananda
      Sep 13 at 15:01












    up vote
    1
    down vote










    up vote
    1
    down vote









    This question is verging on soliciting personal opinion. An administrator is allowed to set up their system in such a way that it suits them, and if the default setup is annoying you I would suggest that you change it.



    However...



    The root user is not an ordinary user, and every action taken at the interactive prompt while logged in as root should ideally be carefully considered. To remind an admin that they are logged in as root, the root prompt in most shells are by default different from the default prompt for privileged users, and indeed, working at a root prompt should remind you that you actually shouldn't be there for very long, if at all1.



    One reason vi is not aliased to vim might me that in a situation where shared libraries have gone AWOL (due to a disk failure or accidental deletion), vi may be a static executable that would work anyway (or it may be linked with libraries from another path), allowing the administrator to edit files to get the rest of the system up and running again.



    The same reasoning can be applied to other "bells and whistles" that ordinary users may enjoy. In situations where an admin may be forced to bring up an interactive root shell, the dependencies of the extra features may simply not be available.




    1Working at a root prompt, you have no audit trail of the commands that you have typed. It is therefore better to use facilities such as sudo to do root-related tasks since sudo by default logs who does what when. This is extra important on systems where more than one person has admin rights and on corporate systems.






    share|improve this answer














    This question is verging on soliciting personal opinion. An administrator is allowed to set up their system in such a way that it suits them, and if the default setup is annoying you I would suggest that you change it.



    However...



    The root user is not an ordinary user, and every action taken at the interactive prompt while logged in as root should ideally be carefully considered. To remind an admin that they are logged in as root, the root prompt in most shells are by default different from the default prompt for privileged users, and indeed, working at a root prompt should remind you that you actually shouldn't be there for very long, if at all1.



    One reason vi is not aliased to vim might me that in a situation where shared libraries have gone AWOL (due to a disk failure or accidental deletion), vi may be a static executable that would work anyway (or it may be linked with libraries from another path), allowing the administrator to edit files to get the rest of the system up and running again.



    The same reasoning can be applied to other "bells and whistles" that ordinary users may enjoy. In situations where an admin may be forced to bring up an interactive root shell, the dependencies of the extra features may simply not be available.




    1Working at a root prompt, you have no audit trail of the commands that you have typed. It is therefore better to use facilities such as sudo to do root-related tasks since sudo by default logs who does what when. This is extra important on systems where more than one person has admin rights and on corporate systems.







    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited Sep 13 at 14:51

























    answered Sep 13 at 14:44









    Kusalananda

    107k14209331




    107k14209331







    • 2




      vi (and the standard editor, ed) is dynamically linked on Centos 7 so if you screw up libc.so you probably need some other plan
      – thrig
      Sep 13 at 14:51










    • @thrig Yes, and it may well be a "tiny" vim. It should at least be linked to fewer libraries. Hmm...
      – Kusalananda
      Sep 13 at 15:01












    • 2




      vi (and the standard editor, ed) is dynamically linked on Centos 7 so if you screw up libc.so you probably need some other plan
      – thrig
      Sep 13 at 14:51










    • @thrig Yes, and it may well be a "tiny" vim. It should at least be linked to fewer libraries. Hmm...
      – Kusalananda
      Sep 13 at 15:01







    2




    2




    vi (and the standard editor, ed) is dynamically linked on Centos 7 so if you screw up libc.so you probably need some other plan
    – thrig
    Sep 13 at 14:51




    vi (and the standard editor, ed) is dynamically linked on Centos 7 so if you screw up libc.so you probably need some other plan
    – thrig
    Sep 13 at 14:51












    @thrig Yes, and it may well be a "tiny" vim. It should at least be linked to fewer libraries. Hmm...
    – Kusalananda
    Sep 13 at 15:01




    @thrig Yes, and it may well be a "tiny" vim. It should at least be linked to fewer libraries. Hmm...
    – Kusalananda
    Sep 13 at 15:01










    up vote
    1
    down vote













    Decisions like this usually hinge upon catering to concerns about ease of maintenance and safety, albeit that security, mentioned in other answers, is a factor. Some system administrators don't want odd undocumented personal customizations for the superuser's interactive environment. They want things to behave in the standard, documented, ways; with no nasty surprises. They moreover want to avoid having to re-apply personal customizations after fresh installations, system upgrades, and so forth.



    In the case of vi, aliasing it to vim potentially brings up a different program on CentOS, /usr/bin/vim instead of /bin/vi. The former is an optional "enhanced VIM" that could be present, with all sorts of features compiled in, whereas the latter is "tiny VIM" with very few optional features enabled. (Ubuntu has a similar idea.) People generally want the vi command to behave as the standard vi command, especially when doing stuff as the superuser. They don't want some enhanced whiz-bang feature or plug-in altering stuff in surprising ways; or, worse, breaking in rescue or emergency modes. They don't want all of the vi reference doco that someone doing critical work as the superuser consults, to be drastically erroneous because of such things.



    This means invoking vi when the adminstrator asks for vi, not vim.



    Put another way: Whereas you have come to take all sorts of VIM customizations and extensions for granted, what some other people tend to take for granted is that the superuser account does not have such customizations and extensions. They build that assumption into WWW pages, Q&A answers, and books that they write. They form habits and carry knowledge from one system to the next of what they'll get when the superuser runs vi. (And sometimes this is that it has VIMisms, ironically. One of the things that people have to learn going from a Linux operating system to FreeBSD is that vi is nvi and not any flavour of VIM at all.)



    Moreover: They want not to have to remember to carry /root/.vimrc and /root/.gvimrc over hard disc changes, system reinstallations, and the like; in addition to the system-wide configuration files.



    Another example of this thinking in action is the toor account on FreeBSD. It's the superuser, but with a Bourne-like shell (the Almquist shell, in fact). The root account has the TENEX C shell, and because there are decades-worth of BSD doco that show the superuser driving the system with the C shell, advice that people give is to leave that as it is, and use toor for Bourne-like interaction. The C shell is the expected environment when logging in as root, and if it came up with a Bourne-like shell for a superuser who had (say) a book of C shell instructions for administering FreeBSD, hilarity and indeed potentially disaster would ensue.



    Further reading



    • "vi". Shell and Utilities. Single UNIX Specification. Issue 7. IEEE 1003.1. 2018. The Open Group.

    • https://askubuntu.com/questions/281886/

    • Dru Lavigne (February 2009). BSD Hacks: 100 Industrial Tip & Tools. O'Reilly Media. ISBN 9780596006792.

    • https://unix.stackexchange.com/a/397056/5132

    • Sven Guckes (2017). Vi Clones and HomePages. guckes.net.





    share|improve this answer
























      up vote
      1
      down vote













      Decisions like this usually hinge upon catering to concerns about ease of maintenance and safety, albeit that security, mentioned in other answers, is a factor. Some system administrators don't want odd undocumented personal customizations for the superuser's interactive environment. They want things to behave in the standard, documented, ways; with no nasty surprises. They moreover want to avoid having to re-apply personal customizations after fresh installations, system upgrades, and so forth.



      In the case of vi, aliasing it to vim potentially brings up a different program on CentOS, /usr/bin/vim instead of /bin/vi. The former is an optional "enhanced VIM" that could be present, with all sorts of features compiled in, whereas the latter is "tiny VIM" with very few optional features enabled. (Ubuntu has a similar idea.) People generally want the vi command to behave as the standard vi command, especially when doing stuff as the superuser. They don't want some enhanced whiz-bang feature or plug-in altering stuff in surprising ways; or, worse, breaking in rescue or emergency modes. They don't want all of the vi reference doco that someone doing critical work as the superuser consults, to be drastically erroneous because of such things.



      This means invoking vi when the adminstrator asks for vi, not vim.



      Put another way: Whereas you have come to take all sorts of VIM customizations and extensions for granted, what some other people tend to take for granted is that the superuser account does not have such customizations and extensions. They build that assumption into WWW pages, Q&A answers, and books that they write. They form habits and carry knowledge from one system to the next of what they'll get when the superuser runs vi. (And sometimes this is that it has VIMisms, ironically. One of the things that people have to learn going from a Linux operating system to FreeBSD is that vi is nvi and not any flavour of VIM at all.)



      Moreover: They want not to have to remember to carry /root/.vimrc and /root/.gvimrc over hard disc changes, system reinstallations, and the like; in addition to the system-wide configuration files.



      Another example of this thinking in action is the toor account on FreeBSD. It's the superuser, but with a Bourne-like shell (the Almquist shell, in fact). The root account has the TENEX C shell, and because there are decades-worth of BSD doco that show the superuser driving the system with the C shell, advice that people give is to leave that as it is, and use toor for Bourne-like interaction. The C shell is the expected environment when logging in as root, and if it came up with a Bourne-like shell for a superuser who had (say) a book of C shell instructions for administering FreeBSD, hilarity and indeed potentially disaster would ensue.



      Further reading



      • "vi". Shell and Utilities. Single UNIX Specification. Issue 7. IEEE 1003.1. 2018. The Open Group.

      • https://askubuntu.com/questions/281886/

      • Dru Lavigne (February 2009). BSD Hacks: 100 Industrial Tip & Tools. O'Reilly Media. ISBN 9780596006792.

      • https://unix.stackexchange.com/a/397056/5132

      • Sven Guckes (2017). Vi Clones and HomePages. guckes.net.





      share|improve this answer






















        up vote
        1
        down vote










        up vote
        1
        down vote









        Decisions like this usually hinge upon catering to concerns about ease of maintenance and safety, albeit that security, mentioned in other answers, is a factor. Some system administrators don't want odd undocumented personal customizations for the superuser's interactive environment. They want things to behave in the standard, documented, ways; with no nasty surprises. They moreover want to avoid having to re-apply personal customizations after fresh installations, system upgrades, and so forth.



        In the case of vi, aliasing it to vim potentially brings up a different program on CentOS, /usr/bin/vim instead of /bin/vi. The former is an optional "enhanced VIM" that could be present, with all sorts of features compiled in, whereas the latter is "tiny VIM" with very few optional features enabled. (Ubuntu has a similar idea.) People generally want the vi command to behave as the standard vi command, especially when doing stuff as the superuser. They don't want some enhanced whiz-bang feature or plug-in altering stuff in surprising ways; or, worse, breaking in rescue or emergency modes. They don't want all of the vi reference doco that someone doing critical work as the superuser consults, to be drastically erroneous because of such things.



        This means invoking vi when the adminstrator asks for vi, not vim.



        Put another way: Whereas you have come to take all sorts of VIM customizations and extensions for granted, what some other people tend to take for granted is that the superuser account does not have such customizations and extensions. They build that assumption into WWW pages, Q&A answers, and books that they write. They form habits and carry knowledge from one system to the next of what they'll get when the superuser runs vi. (And sometimes this is that it has VIMisms, ironically. One of the things that people have to learn going from a Linux operating system to FreeBSD is that vi is nvi and not any flavour of VIM at all.)



        Moreover: They want not to have to remember to carry /root/.vimrc and /root/.gvimrc over hard disc changes, system reinstallations, and the like; in addition to the system-wide configuration files.



        Another example of this thinking in action is the toor account on FreeBSD. It's the superuser, but with a Bourne-like shell (the Almquist shell, in fact). The root account has the TENEX C shell, and because there are decades-worth of BSD doco that show the superuser driving the system with the C shell, advice that people give is to leave that as it is, and use toor for Bourne-like interaction. The C shell is the expected environment when logging in as root, and if it came up with a Bourne-like shell for a superuser who had (say) a book of C shell instructions for administering FreeBSD, hilarity and indeed potentially disaster would ensue.



        Further reading



        • "vi". Shell and Utilities. Single UNIX Specification. Issue 7. IEEE 1003.1. 2018. The Open Group.

        • https://askubuntu.com/questions/281886/

        • Dru Lavigne (February 2009). BSD Hacks: 100 Industrial Tip & Tools. O'Reilly Media. ISBN 9780596006792.

        • https://unix.stackexchange.com/a/397056/5132

        • Sven Guckes (2017). Vi Clones and HomePages. guckes.net.





        share|improve this answer












        Decisions like this usually hinge upon catering to concerns about ease of maintenance and safety, albeit that security, mentioned in other answers, is a factor. Some system administrators don't want odd undocumented personal customizations for the superuser's interactive environment. They want things to behave in the standard, documented, ways; with no nasty surprises. They moreover want to avoid having to re-apply personal customizations after fresh installations, system upgrades, and so forth.



        In the case of vi, aliasing it to vim potentially brings up a different program on CentOS, /usr/bin/vim instead of /bin/vi. The former is an optional "enhanced VIM" that could be present, with all sorts of features compiled in, whereas the latter is "tiny VIM" with very few optional features enabled. (Ubuntu has a similar idea.) People generally want the vi command to behave as the standard vi command, especially when doing stuff as the superuser. They don't want some enhanced whiz-bang feature or plug-in altering stuff in surprising ways; or, worse, breaking in rescue or emergency modes. They don't want all of the vi reference doco that someone doing critical work as the superuser consults, to be drastically erroneous because of such things.



        This means invoking vi when the adminstrator asks for vi, not vim.



        Put another way: Whereas you have come to take all sorts of VIM customizations and extensions for granted, what some other people tend to take for granted is that the superuser account does not have such customizations and extensions. They build that assumption into WWW pages, Q&A answers, and books that they write. They form habits and carry knowledge from one system to the next of what they'll get when the superuser runs vi. (And sometimes this is that it has VIMisms, ironically. One of the things that people have to learn going from a Linux operating system to FreeBSD is that vi is nvi and not any flavour of VIM at all.)



        Moreover: They want not to have to remember to carry /root/.vimrc and /root/.gvimrc over hard disc changes, system reinstallations, and the like; in addition to the system-wide configuration files.



        Another example of this thinking in action is the toor account on FreeBSD. It's the superuser, but with a Bourne-like shell (the Almquist shell, in fact). The root account has the TENEX C shell, and because there are decades-worth of BSD doco that show the superuser driving the system with the C shell, advice that people give is to leave that as it is, and use toor for Bourne-like interaction. The C shell is the expected environment when logging in as root, and if it came up with a Bourne-like shell for a superuser who had (say) a book of C shell instructions for administering FreeBSD, hilarity and indeed potentially disaster would ensue.



        Further reading



        • "vi". Shell and Utilities. Single UNIX Specification. Issue 7. IEEE 1003.1. 2018. The Open Group.

        • https://askubuntu.com/questions/281886/

        • Dru Lavigne (February 2009). BSD Hacks: 100 Industrial Tip & Tools. O'Reilly Media. ISBN 9780596006792.

        • https://unix.stackexchange.com/a/397056/5132

        • Sven Guckes (2017). Vi Clones and HomePages. guckes.net.






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Sep 13 at 17:58









        JdeBP

        29.7k461136




        29.7k461136



























             

            draft saved


            draft discarded















































             


            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f468804%2fwhy-doesnt-root-alias-vi-to-vim-if-its-standard-for-other-users%23new-answer', 'question_page');

            );

            Post as a guest













































































            Popular posts from this blog

            How to check contact read email or not when send email to Individual?

            How many registers does an x86_64 CPU actually have?

            Nur Jahan