技术学无止尽

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 124|回复: 0

Ubuntu系统的常用命令

[复制链接]

297

主题

301

帖子

1659

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1659
发表于 2024-9-13 14:19:31 | 显示全部楼层 |阅读模式
username: ry2uzfxh
password: 0289ab64

一、用户管理类
1、创建新用户
# 创建新用户
sudo useradd -m <新用户名>    # -m 选项告诉 useradd 创建用户的主目录。

# 为新用户设置密码
sudo passwd <新用户名>

# 将 <新用户#名> 添加到 sudo 组,使其具有执行管理员命令的能力。
sudo usermod -aG sudo <新用户名>

修改/etc/sudoers文件可以设置用户使用sudo时不用输密码 ,配置如下:
# Allow members of group sudo to execute any command
%sudo   ALL=(ALL:ALL) ALL
san.zhang    ALL=(ALL:ALL) NOPASSWD:ALL
2、修改用户信息
2.1、usermod
2.1.1、简介
usermod是Linux和Unix系统中用于修改用户属性的命令。它允许管理员更改用户的各种设置,如用户名、主目录、默认shell、用户组等。以下是一些usermod命令的常见用法和选项:

2.1.2、常见用法
# 修改用户名
usermod -l <新用户名> <旧用户名>

# 修改用户的主目录
usermod -d <新主目录> <用户名>

# 添加用户到附加组
usermod -aG <附加组> <用户名>

# 修改用户组(即修改用户的主组)
usermod -g <新组> <用户名>

# 修改用户的默认shell
usermod -s <新shell> <用户名>

#常见选项
-c:修改用户的备注信息。
-e:设置账户的过期时间。
-f:设置在passwd文件中记录用户密码失效前的天数。
-g:修改用户的主组。
-G:为用户添加或删除附加组。
-L:锁定用户账户,使其不能登录。
-m:移动用户的主目录内容到新位置(与-d选项一起使用)。
-p:修改用户的密码。
-u:修改用户的UID(User ID)。

2.2、passwd
2.2.1、简介
passwd 命令在 Linux 和 Unix 系统中用于设置或更改用户密码

​2.2.2、常见用法
# 为当前用户设置或更改密码
passwd

# 为指定用户设置或更改密码
sudo passwd <用户名>

# 锁定用户账户
sudo passwd -l <用户名>

# 解锁用户账户
sudo passwd -u <用户名>

# 查看账户密码状态(需要root权限)
sudo passwd -S <用户名>

# 从标准输入读取密码(通常用于脚本)
echo "新密码" | sudo passwd --stdin <用户名>

二、文件管理类
1、文件权限管理
1.1、修改文件权限
# 使用chmod命令修改文件权限,r -> 读,w -> 写,x -> 可执行

# 示例

# 给file文件增加可执行权限
chmod +x file

# 给file文件坚强可执行权限
chmod -x file

# 给file文件添加最高权限
chmod 777 file

# 给当前目录下所有文件添加最高权限
chmod 777 *

# 递归当前目录及子目录下的文件添加最高权限
chmod -R 777 *


2、文件打包压缩
2.1、tar
# 将a.c文件打包为test.tar.gz
tar -czvf test.tar.gz a.c

# 解压  
tar -xzvf test.tar.gz
2.2、zip和unzip
# 压缩文件
zip archive.zip file1.txt file2.txt

# 压缩目录及其子目录
zip -r archive.zip directory/

# 更新已存在的ZIP文件
zip -u archive.zip newfile.txt

# 解压缩ZIP文件
unzip archive.zip
2.3、7z
# 在当前目录下解压缩filename.7z文件
7z x filename.7z

# 将filename.7z文件解压缩到指定目录/path/to/directory下
7z x filename.7z -o/path/to/directory

# 将文件或目录file_or_directory压缩成archive.7z
7z a archive.7z file_or_directory

# 列出filename.7z压缩包的内容,但不进行解压缩
7z l filename.7z

# 常用选项
a:向压缩包中添加文件或目录。
d:从压缩包中删除文件或目录。
e:从压缩包中提取文件或目录(不使用目录名)。
h:计算文件或目录的哈希值。
i:显示支持的压缩格式信息。
l:列出压缩包的内容。
r:递归处理子目录。
t:测试压缩包的完整性。
u:更新压缩包内的文件。
x:以完整路径解压文件。

3、文件传输
3.1 scp
3.1.1、简介
scp命令是一个在Linux和Unix系统中用于在本地和远程主机之间安全地复制文件的命令行工具。它使用SSH协议进行加密传输,因此可以确保数据传输的安全性。

3.1.2、基本用法
# 基本语法
scp [选项] [[用户@]来源主机:]文件路径 [[用户@]目标主机:]文件路径

# 从本地复制到远程
scp /path/to/local/file username@remote:/path/to/destination

# 从远程复制到本地
scp username@remote:/path/to/remote/file /path/to/local/destination

# 使用密钥文件进行身份验证
scp -i /path/to/private_key username@remote:/path/to/remote/file /path/to/local/destination

# 常用选项
-r:递归复制整个目录及其内容。
-p:保留源文件的属性,包括文件的权限和时间戳。
-v:详细输出,显示详细的传输过程,有助于发现问题和调试。
-q:静默模式,不显示传输过程。
-C:开启压缩传输,加快传输速度。
-l:限制传输速度,指定带宽限制。
-4:强制使用IPv4协议进行传输。
-6:强制使用IPv6协议进行传输。
-i <密钥文件>:使用指定的密钥文件进行身份验证。
-P <端口号>:指定远程主机的端口号。

4、编辑文件
在Ubuntu中编辑文件,可以使用多种文本编辑器。

4.1、nano
nano 是一个简单的文本编辑器。

nano filename.txt
在nano中,可以使用以下基本快捷键:

Ctrl + O:保存文件
Ctrl + X:退出编辑器
Ctrl + W:查找单词
Ctrl + K:剪切文本行
Ctrl + U:粘贴文本
Alt + A:移动到行首
Alt + E:移动到行尾
4.2、vim 或 vi
vim(或vi)是一个强大的文本编辑器,它是一个非常高效的工具。

vim filename.txt
vi filename.txt
在vim中,首先需要进入插入模式来编辑文本。可以按 i 进入插入模式,然后按 Esc 退出插入模式。在普通模式下,可以使用以下命令:

:w:保存文件
:q:退出编辑器
:wq:保存并退出
dd:删除当前行
yy:复制当前行
p:粘贴
/keyword:搜索keyword
:set number:显示行号
4.3、sed
sed是一个流编辑器,用于对输入流(或文件)进行基本的文本转换。它经常用于替换文本、删除行等。

# 替换文本中的“old”为“new”
sed 's/old/new/g' filename.txt

# 删除包含“error”的行
sed '/error/d' filename.txt

# 在文件的第一行前插入文本
sed -i '1i\Inserted text' filename.txt # sed的-i选项会直接修改文件

# 去除文件中的M格式
sed -i 's/\r//g' filename.txt  

# 修改s文件中的-d 0为-d 1
sed -i 's/-d 0/-d 1/g' filename.txt

# 删除第3~13行
sed '3,13d' filename.txt



5、查看文件
在Ubuntu中,可以使用多种命令来查看文件的内容。以下是一些常用的命令:

5.1、cat
# 查看整个文件内容
cat filename.txt

# 显示文件的前10行
cat filename.txt | head -n 10  

# 显示文件的最后10行
cat filename.txt | tail -n 10
5.2、more 和 less
more filename.txt
在more中,可以按空格键来查看下一页,按Enter键来查看下一行,按q键来退出。

less filename.txt
less比more更强大,它允许向前和向后浏览文件,搜索文本等。在less中,可以使用以下快捷键:

空格键:向下翻页
b:向上翻页
/text:搜索包含text的行
n:搜索下一个匹配项
N:搜索上一个匹配项
q:退出less
5.3、head 和 tail
head命令用于显示文件的开头部分,而tail命令用于显示文件的结尾部分。

# 默认显示文件的前10行
head filename.txt

# 默认显示文件的最后10行  
tail filename.txt  

# 显示文件的前20行
head -n 20 filename.txt  

# 显示文件的最后50行  
tail -n 50 filename.txt  


5.6、grep和awk
grep用于在文件中搜索指定的模式,并将匹配的行打印出来。

# 搜索包含“error”的行
grep 'error' log.txt

# 搜索不区分大小写的“ERROR”或“error”
grep -i 'error' log.txt

# 显示匹配行的行号
grep -n 'error' log.txt
awk是一个文本分析工具,它允许基于模式扫描和处理文本。awk通常用于报告生成和数据提取。

# 打印第一列
awk '{ print $1 }' filename.txt

# 打印文件大小大于1000的行
awk '$1 > 1000' filesize.txt
grep和awk结合使用

# 搜索包含“error”的行,并打印每行的第二列
grep 'error' log.txt | awk '{ print $2 }'
6、查找文件

find 是 Unix 和类 Unix 系统(如 Ubuntu)中非常强大的命令行工具,用于在目录树中查找文件。它可以根据各种条件(如文件名、文件类型、大小、修改日期等)来搜索文件。

# 查找当前目录及其子目录中所有的 .txt 文件
find . -name "*.txt"

# 查找 /home/user 目录下所有的目录
find /home/user -type d

# 查找最近 7 天内修改过的文件
find . -type f -mtime -7

# 查找大于 1M 的文件
find . -type f -size +1M

# 查找所有空文件
find . -type f -empty

# 找到所有的 .txt 文件并删除它们
find . -name "*.txt" -exec rm {} \;

# 使用 xargs 处理大量文件
find . -name "*.txt" | xargs rm
find ./ -name "*.sh" | xargs -i rm {}

# 常用选项:
-name:按照文件名查找文件。
-type:按照文件类型查找,如 d 表示目录,f 表示普通文件。
-size:按照文件大小查找。
-mtime:按照文件的修改时间查找。
-atime:按照文件的访问时间查找。
-ctime:按照文件的创建时间查找(实际上是inode改变时间)。
-user:按照文件属主查找。
-group:按照文件属组查找。
-exec:对匹配的文件执行指定的 shell 命令。
-ok:和 -exec 的作用相同,不过会以更为安全的模式来执行该参数所给出的 shell 命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

三、服务安装类
1、网络配置
1.1、ifconfig
ifconfig命令主要用于配置和显示Linux内核中网络接口的网络参数。

# 更新软件包列表
sudo apt update

# 安装 net-tools 包
sudo apt install net-tools

# 显示所有网络接口的信息
ifconfig

# 显示特定网络接口的信息
ifconfig eth0

# 启动或关闭网络接口
sudo ifconfig eth0 down  
sudo ifconfig eth0 up

# 配置网络接口的 IP 地址
sudo ifconfig eth0 192.168.1.100 netmask 255.255.255.0

# 配置广播地址
sudo ifconfig eth0 broadcast 192.168.1.255

# 启用或禁用网络接口上的混杂模式
sudo ifconfig eth0 promisc
# 混杂模式允许网络接口接收所有到达的数据包,禁用它可以使用 -promisc 选项

1.2、route
route命令是一个在Linux和类Unix系统中用于操作IP路由表的命令行工具。

# 添加网关
route add default gw 192.168.1.1

# 添加一个静态路由
route add -net 192.168.105.0 netmask 255.255.255.0 gw 192.168.105.225

# 删除一个静态路由
route delete -net 192.168.105.0 netmask 255.255.255.0 gw 192.168.105.225

# 显示路由表
route -n
1.3、ip
ip命令是Linux加强版的网络配置工具,用于代替ifconfig命令。它整合了ifconfig与route这两个命令的功能,并提供了更强大的网络配置能力。

# 显示所有网络接口的信息
ip addr show        # 简写 ip a s        

# 查看特定网络接口的信息
ip addr show eth0

# 配置网络接口的 IP 地址
ip addr add 192.168.1.100/24 dev eth0

# 配置网络接口的网关
ip route add default via 192.168.1.1

# 查看路由表
ip route show       # 简写 ip r s

# 删除网络接口中配置的 IP 地址
sudo ip addr del 192.168.1.100/24 dev eth0

2、nfs挂载
2.1、安装nfs客户端
# 更新软件包列表
sudo apt update  

#安装nfs服务
sudo apt install nfs-kernel-server

2.2、 创建本地挂载点
在本地系统上选择一个目录作为nfs共享的挂载点。这个目录可以是空的,因为在挂载时,nfs共享的内容会覆盖它。

# 1. 创建nfs挂载目录
sudo mkdir /mnt/nfs

# 2. 配置nfs共享
sudo vi /etc/exports

# 3. 添加如下行来配置共享目录
/mnt/nfs *(rw,sync,no_subtree_check,no_root_squash)

# 4. 导出配置并重启服务
sudo exportfs -r -a
sudo service nfs-kernel-server restart

2.3、挂载nfs共享
sudo mount -t nfs -o nolock $server_ip:/mnt/nfs/ /userdata/
3、ssh服务
3.1、安装SSH服务器
打开终端(在Ubuntu中,可以通过按下Ctrl+Alt+T组合键来打开终端)
确保软件包列表是最新的,执行以下命令:sudo apt update
安装SSH服务器,执行以下命令:sudo apt install openssh-server
3.2、确认SSH服务状态
在终端中输入以下命令来检查SSH服务的状态:sudo service ssh status
如果服务已经启动,将看到类似于“ssh start/running, process 1234”的输出
如果SSH服务未启动,可以使用以下命令手动启动SSH服务:sudo service ssh start
3.3、配置SSH在系统启动时自动启动
在终端中输入以下命令来检查SSH服务是否在系统启动时自动启动:sudo systemctl is-enabled ssh
如果输出为“enabled”,则表示SSH服务已经配置为在系统启动时自动启动。如果不是,可以使用以下命令启用自动启动:sudo systemctl enable ssh
3.4、启用ufw并开放SSH端口(默认为22)
安装ufw(如果尚未安装):sudo apt install ufw
启用ufw:sudo ufw enable
开放SSH端口:sudo ufw allow 22
3.5、ssh服务保活
编辑sshd_config文件:sudo vi /etc/ssh/sshd_config
取消 ClientAliveInterval 和 ClientAliveCountMax 字段的注释,并且设置为:ClientAliveInterval 60;ClientAliveCountMax 3,保存并退出
重启ssh服务:sudo systemctl restart sshd 或 sudo service ssh restart
4、安装fastboot服务
# 更新系统软件包
sudo apt update
sudo apt upgrade

# 安装fastboot
sudo apt install android-tools-fastboot

# 验证安装
fastboot devices # 如果设备正确连接并且fastboot已成功安装,则应该能够看到设备的序列号。
5、开启或关闭防火墙
5.1、开启防火墙
开启防火墙:sudo ufw enable
查看防火墙状态:sudo ufw status,如果终端输出“Status: active”,则表示防火墙已成功开启
检查ufw服务是否已启用开机自启:sudo systemctl is-enabled ufw;如果输出为enabled,则表示ufw已经设置为开机自启;如果不是,则用sudo systemctl enable ufw开开启
5.2、关闭防火墙
停止防火墙服务:sudo systemctl stop ufw.service
禁用防火墙服务,使其在下次系统启动时不会自动运行:sudo systemctl disable ufw.service
查看防火墙状态:sudo ufw status,如果终端输出“Status: inactive”,则表示防火墙已成功关闭














回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|DiscuzX

GMT+8, 2025-5-4 18:07 , Processed in 0.048800 second(s), 21 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表