Guides - Grant a Developer Access a Compute Instance or Linode Account
One of the most powerful features of Linode’s unmanaged service is the amount of control Linode users have over their account and the software installed on their systems. If you’re a business owner that does not have expertise with installing or maintaining software on Linux, or if you do have experience with Linux but don’t have the time to set up a new server, then contracting with a developer or administrator is a popular way to get your services up and running.
What to Keep Track of when Hiring a Developer
When you hire someone to work on your Linode, there are a variety of ways to grant access to your Linode account, the Compute Instances on it, and the system and applications on those instances. Recording which of these credentials you’ve shared is important if you need to end your contract with your developer.
This guide explains and answers some of the most frequently asked questions about account access. The sections are separated in order of granularity, starting with service-level access at the top, and working towards application-specific access.
For security and privacy, Linode Support is not able to troubleshoot issues related to users and application access. Instead, Linode offers an in-house Professional Services team that can be hired to help with projects. You can reach out to that team through the Contact Sales form.
exampleUser
in place of your users’ names. Replace exampleUser
with whatever you would like to name your users.Cloud Manager Access
Access to Cloud Manager provides high-level methods for controlling your Compute Instances and Linode billing, including but not limited to: powering Compute Instances down, powering them on, removing services, and adding services. Cloud Manager does not have interfaces for manipulating the files and software on your systems–instead, that access is governed by service-specific credentials outlined in the next sections.
Who Has Access to My Linode Account?
Log in to Cloud Manager and navigate to the Users and Permissions section of the Account tab. You may be prompted to reauthenticate your password. This section will display all of your Linode account’s users.
If you’re not sure whether you’re logged in as the account administrator, look for a No
in the Restricted column of your username’s row in the User Manager.
Add a User to the Linode Account
Keep your account administrator credentials secret. When hiring an external individual or agency to work on your site or application, create a restricted user and assign specific access to the account. Learn more about how to manage users and permissions and how to recover a lost username in our Accounts and Passwords guide.
Useful Global Grants for a limited access user might include the ability to:
- Add a NodeBalancer.
- Add Longview clients.
- Use the DNS Manager to add domains.
- Create StackScripts.
- Create Images.
- Add Block Storage Volumes.
Revoke a User’s Access to the Linode Account
If you suspect that the user may have access to their Cloud Manager password, change that first.
Log in to Cloud Manager and click Users and Permissions in the Account tab. You may be prompted to reauthenticate your password.
Locate the user in the Username column, and click the three dots and select Delete to remove the user. Click Delete to confirm deletion.
SSH Logins
The primary method for directly administering files and software on a Compute Instance is through SSH. SSH is a service that runs on a system and listens for and accepts remote terminal connections. Once an SSH connection is opened, a user can issue commands to your server. Your Compute Instance’s SSH users are not the same as your Cloud Manager users.
For the steps in this section,
connect to your Compute Instance via SSH to log in to the system as root
, which is the primary administrative (and most powerful) user on every Linux system. Alternatively, you can login as non-root user with sudo (i.e. administrative) permissions.
Who Has SSH Access to Your Compute Instance?
Use getent
to display the list of users. Keep in mind that some applications create Linux users as part of their normal operation, and those users will be listed here too.
getent passwd
Add an SSH User
Create a limited Linux user account on your Compute Instance. Set a unique and secure password for this user.
Create a User Group with Specific Permissions
As an optional alternative to setting permissions for each user, create a limited privilege user group that can be reused and combined with other groups if needed.
Add the group. Replace
devGroup
in these examples to a group name you’ll remember:groupadd devGroup
Add the user to the group and specify a new home directory for the user:
usermod -g devGroup -d /var/www/html/example.com exampleUser
Restrict a User to a Specific Directory
If your user should only have access to a specific directory and its subdirectories, for example /var/www/html/example.com/
, use chroot
jails, as described in the
Advanced SSH Security guide.
Restrict a User to SFTP Only
For some applications, a user may only need to transfer files to or from the server. In this case, create a user that can transfer files through SFTP but that can’t access the server with SSH.
Consult our guide to configure this using SFTP jails on Debian or Ubuntu.
Change the
sftp
subsystem line and add aMatch Group sftpOnly
section insshd_config
:- File: /etc/ssh/sshd_config
1 2 3 4 5 6 7 8
... Subsystem sftp internal-sftp ... Match Group sftpOnly ChrootDirectory %h X11Forwarding no AllowTcpForwarding no ForceCommand internal-sftp
Create an
sftpOnly
group that will only have SFTP access:groupadd sftpOnly
Add a user to the group and disable their SSH access. Change both the user name and home directory:
usermod -g sftpOnly -d /home/exampleUser -s /sbin/nologin exampleUser
Restart the SSH service:
systemctl restart ssh
Change the ownership of the directory the user should have access to:
chown -R exampleUser:sftpOnly /var/www/html/example.com
The user can now sftp
to the system and transfer files to and from the specified directory.
Revoke Access for an SSH User
To revoke access to an SSH user, change the password for that user:
passwd exampleUser
In addition to password authentication, a user may rely on public key authentication to connect via SSH. For any users that you would like to revoke access on, you should also check for the presence of a public key.
These public keys are listed as line in a text file in the user’s home directory named /home/exampleUser/.ssh/authorized_keys
. To see which keys are present, run:
cat /home/exampleUser/.ssh/authorized_keys
The output will resemble the following:
ssh-rsa MIIEpQIBAAKCAQEAqOT7+bo5YUnzmBJYifL5b/VrLhHNjI0Sjm0miyZ4HocvSjIJ+Kx1nWP1LjDG0wt6gimXjRrfPCykHFyJwdZO69dK/gJ0GdcejWtC1sJBCSvI9TISXISLBNXr5rLHedhR2wFOJTRkKTquHP5dw2o5UNBBMyuM0wfkv5ggw8ShecIuO6xCw7yYQIg66BIe2G5toL6uasVOBjvJv5iKWKQNx1sf5ICfDJdVjQojtfHiPAyufidAjm4qO4/jOyfTTncu5+IEJCk12YpO66H3COJwbjPcRXlAcHM4CrBdTb8TmYmmStetY5Lmso++OaD4QjlO2TrhIXjoXDccU7/1BpkdpnPiapPuGKlWYa1vLEeUoIYV6NC9rxJCiYd/V//rBupYt4hkbSAbKl3o24gl1qOw/U7p+yelAZmDVWQCqOOdz3RttXyO/MoET9v0z2+1/57/gxLpHdsrPli7SeyrWMax18GM8DyfjVG5DFxYb/V0uTeew3xVzwXL+OnRdfnIsliSPXkmv15Yqbh10AEarK0EjfHR/VOMEgozrRoL8g9t4Yt5xhiWpbG9wk/EKfj3eaVg2AssQcw6IhzsaS5Kj4qr6aj3I6nx4fhTGUdfvmGqRETR8Hcyg7cDZId9qXve5PVxtxE2ROoszpTLkls+rL7L6+e2y9qfO4Np1ssTWz8495QPojjoMUnMIm6ZTVALjudn+eQ== user@example.com
Each SSH public key entry will begin with ssh-rsa
and end with a corresponding email address (e.g. user@example.com
).
To remove a public key, edit the authorized_keys
file and remove the corresponding line. nano
is a simple text editor in Linux that can be used to do this:
nano /home/exampleUser/.ssh/authorized_keys
Use the cursor keys to navigate the file, enter CTRL-O
to save the file, and enter CTRL-X
to exit the editor.
If you instead want to fully remove the file, run:
rm /home/exampleUser/.ssh/authorized_keys
Add or Remove WordPress Users
If your site runs WordPress, add a user with the appropriate permissions.
WordPress user roles are useful for authors and content contributors, but might not be enough for a developer to work on the site. If you don’t feel comfortable sharing the existing administrator account credentials, create an administrator account.
Log in to your WordPress admin, typically through
www.example.com/wp-admin
(whereexample.com
is your site).Click Users, then All users to view a list of current users.
To add a user:
- Click Add New, enter the information, and for Role, select Administrator.
- Click Add New User
To revoke privileges or delete a user:
Click the check box next to the user’s thumbnail.
To change the role:
- Select a different role in Change role to…, then click Change.
To delete the user:
- Click Bulk Actions, select Delete, then click Apply. Click Confirm Deletion to delete the user.
Add and Manage Drupal Users
Drupal’s main administrator account is the User 1 account. This account serves as the root user and can create other users with different permissions and roles.
Create a new user with administrative-level permissions to grant someone the necessary access to maintain your Drupal site.
Log in to the Drupal admin (this may be through your site’s
www.example.com/admin
), and click Manage, then People in the Admin menu.To create a user with administrative privileges, click Add user and fill out the information on the page that follows. Select the Administrator role when prompted.
To view a list of permissions allowed to the Administrator role, return to the People page and click Permissions.
Configure Drupal Roles
If you don’t feel comfortable granting the full list of administrative privileges, create a new Role that can be reused and applied to many users.
Select the Roles tab, then click Add role and give the role an appropriate name on the next page. Click Save to return to the Roles list.
To assign permissions to the new role, click the Permissions tab and locate the new role’s column on the right.
Create a new user as shown above and select the new role when prompted in Step 2.
Remove a Drupal User or Revoke User Permissions
Log in to the site’s Drupal admin (this may be through your site’s
www.example.com/admin
), and click Manage, then People in the Admin menu.Click Edit in the Operations column of the user’s name.
Change the role, or click Cancel account and then choose what should happen with the user’s content of the page that follows.
Once cancelled, the user will appear in the User List with a Blocked status.
MySQL/MariaDB Database Access
In the background of most web servers is a database that keeps track of users, pages, and other information. The database is configured before a content management system (CMS) like WordPress or Drupal is installed.
While some systems allow the Linux root user to circumvent root database login, you may need to know the SQL root user’s password for these steps.
Log in to MySQL
SSH to your Compute Instance as a user with sudo privileges.
Connect to MySQL with
sudo
:sudo mysql -u root
View Existing MySQL Database Users
To display users and their passwords:
SELECT User, Host, Password FROM mysql.user;
View Existing MySQL Databases
While logged in to MySQL:
SELECT DATABASE();
Change a MySQL or MariaDB User’s Password
While logged in to MySQL:
Use
FLUSH PRIVILEGES
before making changes:FLUSH PRIVILEGES;
Set a new password for the user:
ALTER USER 'exampleUser'@'localhost' IDENTIFIED BY 'newPassword';
If using MariaDB, use the
SET PASSWORD
command:SET PASSWORD FOR 'exampleUser' = PASSWORD('newPassword');
Remove a MySQL User
While logged in to MySQL:
DROP USER 'exampleUser'@'localhost';
If using MariaDB:
DROP USER exampleUser;
Add a New MySQL User
Add a new user and grant them access to a specific database. If you are using a CMS and are concerned about access, update SSH login information. You do not need to create a new user, but it might help to update the database password. See the Change WordPress Database Password in MySQL section for more information.
While logged in to MySQL:
CREATE USER 'exampleUser'@'localhost' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON databaseName.* TO 'exampleUser';
Change the WordPress Database Password in MySQL
If you are only trying to change a WordPress user’s login information, see the WordPress Users section. It is rare that anyone should need to modify the database password except in the case of a WordPress migration. Otherwise, it is not likely that you need to follow this section.
Use the previous sections to log in to MySQL and find the WordPress database name and user. Replace
wordpress
andwpuser
in this example with the appropriate names, andnewPassword
with a new secure password:ALTER USER 'wpuser'@'localhost' IDENTIFIED BY 'newPassword'; FLUSH PRIVILEGES; quit
If using MariaDB, use the
SET PASSWORD
command:SET PASSWORD FOR 'wpuser' = PASSWORD('newPassword');
Edit your site’s
wp-config.php
to reflect the changes:
- File: /var/www/html/example.com/public_html/wp-config.php
1 2 3 4 5 6 7 8 9 10 11 12
// ** MySQL settings - You can get this info from your web host ** // /** The name of the database for WordPress */ define('DB_NAME', 'wordpress'); /** MySQL database username */ define('DB_USER', 'wpuser'); /** MySQL database password */ define('DB_PASSWORD', 'newPassword'); /** MySQL hostname */ define('DB_HOST', 'localhost');
This page was originally published on