


How to configure your own linux server
Step 1: Root user login
First, use the root user to log in to the remote host (assuming the IP address is 128.199.209.242 ).
ssh root@128.199.209.242
At this time, a warning will appear on the command line, indicating that this is a new address and there are security risks. Type yes to accept. Then, you should be able to log in to the remote host successfully.
Next, change the password of the root user.
passwd
Step 2: Create a new user
First, add a user group (assumed to be the admin user group here).
addgroup admin
Then, add a new user (assumed to be bill).
useradd -d /home/bill -s /bin/bash -m bill
In the above command, parameter d specifies the user's home directory, parameter s specifies the user's shell, and parameter m indicates that if the directory does not exist, create the directory.
Next, set the new user’s password.
Free video tutorial recommendation: linux video tutorial
passwd bill
Add a new user (bill) to the user group (admin).
usermod -a -G admin bill
Next, set sudo permissions for the new user.
visudo
The visudo command will open the sudo setting file /etc/sudoers and find the following line.
root ALL=(ALL:ALL) ALL
Below this line, add another line.
root ALL=(ALL:ALL) ALL bill ALL=(ALL) NOPASSWD: ALL
The NOPASSWD above means that when switching sudo, you do not need to enter a password. I like this to save trouble. For security reasons, a password can also be enforced.
root ALL=(ALL:ALL) ALL bill ALL=(ALL:ALL) ALL
Then, log out as the root user first, then log in as the new user, and check whether everything is normal up to this point.
exit ssh bill@128.199.209.242
Step Three: SSH Settings
First, make sure the machine has an SSH public key (usually the file ~/.ssh/id_rsa.pub), if not If so, use the ssh-keygen command to generate one (please refer to the SSH tutorial I wrote).
Open another shell window on the local machine and copy the local public key to the authorized_keys file of the server.
cat ~/.ssh/id_rsa.pub | ssh bill@128.199.209.242 'mkdir -p .ssh && cat - >> ~/.ssh/authorized_keys' # 或者在服务器端,运行下面命令 echo "ssh-rsa [your public key]" > ~/.ssh/authorized_keys
Then, enter the server and edit the SSH configuration file /etc/ssh/sshd_config.
sudo cp /etc/ssh/sshd_config ~ sudo nano /etc/ssh/sshd_config
In the configuration file, change the default port 22 of SSH to any integer from 1025 to 65536 (assumed to be 25000 here).
Port 25000
Then, check whether several settings are set as follows, making sure to remove the # sign in front.
Protocol 2 PermitRootLogin no PermitEmptyPasswords no PasswordAuthentication no RSAAuthentication yes PubkeyAuthentication yes AuthorizedKeysFile .ssh/authorized_keys UseDNS no
The above mainly prohibits root user login and password login.
Next, at the end of the configuration file, specify the users allowed to log in.
AllowUsers bill
After saving, exit file editing.
Next, change the permissions of the authorized_keys file.
sudo chmod 600 ~/.ssh/authorized_keys && chmod 700 ~/.ssh/
Then, restart the SSHD.
sudo service ssh restart # 或者 sudo /etc/init.d/ssh restart
The following step is optional. Create a config file in the ~/.ssh folder of your local machine with the following content.
Host s1 HostName 128.199.209.242 User bill Port 25000
Finally, open another shell window on this machine to test whether SSH can log in successfully.
ssh s1
Step 4: Running environment configuration
First, check the regional settings of the server.
locale
If the result is not en_US.UTF-8, it is recommended to set it to it.
sudo locale-gen en_US en_US.UTF-8 en_CA.UTF-8 sudo dpkg-reconfigure locales
Then, update the software.
sudo apt-get update sudo apt-get upgrade
Finally, make some security settings as needed, such as setting up a firewall, closing ports other than HTTP, HTTPs, and SSH, and installing Fail2Ban.
Recommended related articles and tutorials: linux tutorial
The above is the detailed content of How to configure your own linux server. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

VS Code system requirements: Operating system: Windows 10 and above, macOS 10.12 and above, Linux distribution processor: minimum 1.6 GHz, recommended 2.0 GHz and above memory: minimum 512 MB, recommended 4 GB and above storage space: minimum 250 MB, recommended 1 GB and above other requirements: stable network connection, Xorg/Wayland (Linux)

The five basic components of the Linux system are: 1. Kernel, 2. System library, 3. System utilities, 4. Graphical user interface, 5. Applications. The kernel manages hardware resources, the system library provides precompiled functions, system utilities are used for system management, the GUI provides visual interaction, and applications use these components to implement functions.

vscode built-in terminal is a development tool that allows running commands and scripts within the editor to simplify the development process. How to use vscode terminal: Open the terminal with the shortcut key (Ctrl/Cmd). Enter a command or run the script. Use hotkeys (such as Ctrl L to clear the terminal). Change the working directory (such as the cd command). Advanced features include debug mode, automatic code snippet completion, and interactive command history.

To view the Git repository address, perform the following steps: 1. Open the command line and navigate to the repository directory; 2. Run the "git remote -v" command; 3. View the repository name in the output and its corresponding address.

Although Notepad cannot run Java code directly, it can be achieved by using other tools: using the command line compiler (javac) to generate a bytecode file (filename.class). Use the Java interpreter (java) to interpret bytecode, execute the code, and output the result.

Writing code in Visual Studio Code (VSCode) is simple and easy to use. Just install VSCode, create a project, select a language, create a file, write code, save and run it. The advantages of VSCode include cross-platform, free and open source, powerful features, rich extensions, and lightweight and fast.

The main uses of Linux include: 1. Server operating system, 2. Embedded system, 3. Desktop operating system, 4. Development and testing environment. Linux excels in these areas, providing stability, security and efficient development tools.

Causes and solutions for the VS Code terminal commands not available: The necessary tools are not installed (Windows: WSL; macOS: Xcode command line tools) Path configuration is wrong (add executable files to PATH environment variables) Permission issues (run VS Code as administrator) Firewall or proxy restrictions (check settings, unrestrictions) Terminal settings are incorrect (enable use of external terminals) VS Code installation is corrupt (reinstall or update) Terminal configuration is incompatible (try different terminal types or commands) Specific environment variables are missing (set necessary environment variables)
