This article covers a versions of Ubuntu and CentOS that are no longer supported. If you currently operate a server running Ubuntu 12.04 or CentOS 6, we highly recommend upgrading or migrating to a supported version.
Reason: Ubuntu 12.04 reached end of life (EOL) on April 28, 2017, CentOS 6 reached end of life (EOL) on November 30th, 2020, and neither of these operating system versions will receive future security patches or updates. For these reasons, this guide is no longer maintained.
See Instead:
This guide might still be useful as a reference, but may not work on other Ubuntu or CentOS releases. If available, we strongly recommend using a guide written for the version of Ubuntu or CentOS you are using. You can find our collection of tutorials on how to add and delete users here.
The lines that the user needs to enter or customize will be in red in this tutorial! The rest should mostly be copy-and-pastable.
When you log into a new freshly spun up droplet, you are accessing it from the root user. Although this gives you the power to make any changes you need on the server, you are much better off creating another new user with root privileges on the virtual private server. Additionally, if other people will be accessing the virtual server, you will need to make new users for them as well. This tutorial will go over creating a new user, granting them root privileges, and deleting users.
When you perform any root tasks with the new user, you will need to use the phrase “sudo” before the command. This is a helpful command for 2 reasons: 1) it prevents the user making any system-destroying mistakes 2) it stores all the commands run with sudo to a file where can be reviewed later if needed. Keep in mind however, that this user is as powerful as the root user. If you only need a user for a limited number of tasks on the VPS, you do not need to give them root privileges.
This tutorial requires access to the root user or a user with sudo privileges.
You should have received your root password from the welcome email after you launched your droplet.
To add a new user in Ubuntu, use the adduser command, replacing the “newuser” with your preferred username.
sudo adduser newuser
As soon as you type this command, Ubuntu will automatically start the process:
Congratulations—you have just added a new user. You can log out of the root user by typing exit
and then logging back in with the new username and password.
As mentioned earlier, you are much better off using a user with root privileges.
You can create the sudo user by opening the sudoers file with this command:
sudo /usr/sbin/visudo
Adding the user’s name and the same permissions as root under the the user privilege specification will grant them the sudo privileges.
# User privilege specification
root ALL=(ALL:ALL) ALL
newuser ALL=(ALL:ALL) ALL
Press ‘cntrl x’ to exit the file and then ‘Y’ to save it.
Should you find that you find that you no longer want to have a specific user on the virtual private server you can delete them with a single command.
sudo userdel newuser
Finish up by the deleting the user’s home directory:
sudo rm -rf /home/newuser
To add a new user in CentOS, use the adduser command, replacing the “newuser” with your preferred username.
sudo adduser newuser
Follow up by providing the user with a new password, typing and confirming the new password when prompted:
sudo passwd newuser
Congratulations—you have just added a new user and their password. You can log out of the root user by typing exit
and then logging back in with the new username and password.
As mentioned earlier, you are much better off using a user with root privileges.
You can create the sudo user by opening the sudoers file with this command:
sudo /usr/sbin/visudo
You will find the section to make the user privilege modifications at the bottom of the file. Type “a” to start inserting text. Adding the user’s name and the same permissions as root under the the user privilege specification will grant them the sudo privileges.
## Allow root to run any commands anywhere
root ALL=(ALL) ALL
newuser ALL=(ALL) ALL
Save and Exit the file by press “shift” ZZ.
Should you find that you find that you no longer want to have a specific user on the virtual private server you can delete them with a single command.
sudo userdel newuser
You can add the flag “-r” to the command if you would like to simultaneously remove the users’s home directory and files.
sudo userdel -r newuser
Once you have set up the users will you need, you can start building up your VPS. A good place to start is to install the LAMP stack (a collection of basic web server software) on your droplet, using the tutorials below.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
The instructions for centOS6 are wrong. I needed to use: “passwd <username>” instead of “sudo <username> passwd” per the guide.
On Centos, worked as expected. Thanks. Quick question.
Sometimes I like to SFTP into the server and add a folder or a file. For instance, into /etc/nginx dir to add sites to sites-enabled. The problem I am running into is that this new user does not have the rights to add a file into /etc/nginx, I get a permission error. I could ssh in and su, then add the files as root, but I am trying to come up with a solution that is both secure and allows for easier interaction via SFTP when I am in the mood for that.
Any suggestions? I imagine some sort of chown and chmod might be in order.
… here’s what I did to make working via the command line and via SFTP a bit easier within the webroot and various config directories.
chown -R username:nginx /srv chown -R username:nginx /etc/nginx
Seems to be working.
I tried your instructions for Ubuntu 12.04 to no avail. Creating the user worked fine, but your instructions for giving the user root permissions did not work.
On Ubuntu 12.10 I needed to also do
adduser <username> sudo
to enable sudo access to my new username
On ubuntu 12.04 as root I simply did:
sudo adduser bardi sudo adduser bardi sudo
Very easy if you know how!
Hi,
Please fix the syntax for setting password for new user in CentOS. It is supposed to be <pre>sudo passwd newuser</pre>
@Prasenjit Thanks, updated.
On Ubuntu to get sudo access all you need to do is add the user to the sudo group which can simply be done by typing: sudo adduser newuser sudo adduser newuser sudo
You don’t have to manually edit the sudoers file.
I did this now I cannot get back into the /usr/sbin/visudo area. It says:
sudo: >>> /etc/sudoers: syntax error near line 19 <<< sudo: parse error in /etc/sudoers near line 19 sudo: no valid sudoers sources found, quitting sudo: unable to initialize policy plugin
and then it goes back to the prompt.
Any suggestions? Did I add a user the wrong way and if so is there a way to just edit the file I just modified and remote the line I added which, according to the error was entered wrong (obviously)