Ubuntu Server CLI专业提示

基础

网络

获取所有接口的IP地址
networkctl status

显示主机的所有IP地址
hostname -I

启用/禁用接口
ip link set <interface> up
ip link set <interface> down

显示路线
ip route

将使用哪条路线到达主机
ip route get <IP>

安全

显示已登录的用户
w

获取用户密码到期日期
chage -l <user>

设置用户密码到期日期
sudo chage <user>

锁定用户帐户
sudo passwd -l <user>

解锁用户密码
sudo passwd -u <user>

自动检测并禁止滥用IP地址
sudo apt install fail2ban

显示被禁止的IP地址
sudo fail2ban-client status
sudo fail2ban-client status <jail>

将使用哪条路线到达主机
ip route get <IP>

列出打开的端口和关联的进程
sudo ss -tulpn

管理防火墙规则

开启防火墙 sudo ufw enable

列出规则 sudo ufw status

允许端口 sudo ufw allow <port>

拒绝端口 sudo ufw deny <port>

通过SSH远程连接
ssh <user>@<host IP>

Ubuntu服务

启用Ubuntu服务。

访问 ubuntu.com/advantage,获得最多3台机器的免费代币(如果你是ubuntu社区的官方成员,则为50台)。
sudo ua attach <token>

查看Ubuntu Advantage服务的可用性和权利
sudo ua status

启用或禁用服务
sudo ua enable <service>
sudo ua disable <service>

修复CVE/USN
sudo ua fix <cve/usn>

查看软件包更新系统的可用性状态
sudo ubuntu-security-status

查看Livepatch已修补的CVE
canonical-livepatch status --verbose

软件包

搜索程序包
apt search <string>
snap find <string>

列出可用的软件包版本
apt-cache policy <package>

列出可用更新
apt list --upgradable

应用所有可用的更新
sudo apt update && sudo apt upgrade

从Ubuntu归档安装
sudo apt install <package>

从Snap Store安装
sudo snap install <package>

卸载软件
sudo apt remove <package>

删除程序包及其所有配置文件
sudo apt purge <package>

重新安装损坏的包装
sudo apt install -f --reinstall <package>

此软件包提供哪些文件?
dpkg-query -L <package>

哪个包提供了此文件?
dpkg-query -S <path>

文件

列出具有权限和日期的文件
ll

常见文件操作

创建空文件 touch <filename>

创建制定大小文件 fallocate -l <size> <filename>

使用内容创建 echo "<content>" > <filename>

快速文件搜索
locate <filename>

在文件中搜索字符串
grep <string> <filename>

在目录中递归搜索字符串
grep -Iris <string> <directory>

高级

文件

查找最近分钟内修改的文件
find <directory> -mmin -<n> -type f
eg. find . -mmin -5 -type f

仅显示第n列
col<n> "<separator>" <filename>
eg. col2 "," foo.csv

显示分页的文件
less <filename>

显示前行
head -n <n> <filename>

显示最后行
tail -n <n> <filename>

随着文件内容的增加而显示
tail -f <filename>

将目录打包到存档中

tar.gz tar cvzf <target>.tar.gz <source dir>

zip zip -r <target> <source dir>

打开归档文件的包装

tar.gz tar xf <tar.gz file>

zip unzip <zip file>

将文件复制到远程服务器
rsync <filename> <user@server>:<destination>
eg. rsync config.yaml
admin@192.0.0.0:/config

从远程服务器递归复制目录
rsync -avruz <user@server>:<source> <destination>
eg. rsync -avruz admin@192.0.0.0:/
config /tmp

系统

显示内核版本 uname -r

获取根磁盘使用情况 df -h

获取内存使用情况 cat /proc/meminfo

获取系统时间 timedatectl status

设置系统时区
timedatectl list-timezones
sudo timedatectl set-timezone <zone>

获取所有正在运行/失败的服务
systemctl --state running
systemctl --state failed

启动、停止或重新启动服务
systemctl start/stop/restart <service>

获取系统服务的全部内容
systemctl cat <service>

编辑系统服务避免与程序包更新发生冲突
systemctl edit <service>

监视服务的新日志
journalctl -u <service> --since now -f

自启动以来监视所有日志 journalctl --boot 0

获取最近登录的列表 last

显示正在运行的进程 htop

按id终止进程 kill <process id>

按名称终止进程 pkill <process name>

在后台运行命令 <command> &

挂断并登录到文件后仍然活着

nohup <command> >> /var/log/yourcommand.log 2>&1 &

显示后台命令 jobs

将命令 置于前台 fg <n>

工作站上的Ubuntu虚拟机

安装Multipass并启动Ubuntu虚拟机
sudo snap install multipass
multipass launch <image> --name <VM name>

省略 将使用最新的Ubuntu LTS启动虚拟机

查找可用镜像
multipass find

列出现有虚拟机
multipass list

在虚拟机中获取外壳
multipass shell <VM name>

更多帮助在 discourse.ubuntu.com

Micro clouds

启动LXD容器
lxd init
lxc launch ubuntu:18.04 <container name>

或者另一个发行版
lxc launch images:centos/8/amd64 <container name>

将外壳放入LXD容器
lxc exec <name> bash

将文件推送到LXD容器
lxc file push <filename> <container name>/<path>

从LXD容器中提取文件
lxc file pull <destination> <container name>/<file path>

启动LXD虚拟机
lxc launch images:ubuntu/20.04 <vm name> --vm

在LXD虚拟机中获取外壳
lxc exec <name> bash

更多帮助在 linuxcontainers.org/lxd

裸机资源调配

使用MAAS演示启动虚拟机
wget -qO- https://raw.githubusercontent.com/canonical/maas-multipass/main/maas.yml | multipass launch --name maas -c4 -m8GB -d32GB --cloud-init -

查找MAAS演示服务器的IP地址
multipass list | grep maas | awk '{print $3}'

使用多路径列表中的IP访问MAAS仪表板
http://10.x.x.x:5240/
Default username and password is admin:admin

更多帮助在 maas.io

Kubernetes

安装MicroK8并列出可用的附加组件
sudo snap install microk8s --classic
microk8s.status --wait-ready

使用MicroK8s加载项启用辅助Kubernetes服务
microk8s enable <add-ons>

查看MicroK8s节点和正在运行的服务
microk8s.kubectl get nodes
microk8s.kubectl get services

更多帮助在 microk8s.io/docs

架构

安装MicroStack并启动测试实例
sudo snap install microstack --devmode --beta
sudo microstack.init --auto --control
microstack.launch cirros -n test

获取管理员密码
sudo snap get microstack config.credentials.
keystone-password

Access Horizon面板
https://10.20.20.1

更多帮助在 microstack.run/docs

相关推荐
苹果醋342 分钟前
Java8->Java19的初步探索
java·运维·spring boot·mysql·nginx
不是笨小孩i1 小时前
开源AI图片处理工具HivisionIDPhotos安装与证件照制作指南
ubuntu
二十雨辰1 小时前
[linux]docker基础
linux·运维·docker
Jason-河山2 小时前
【自动化更新,让商品信息跳舞】——利用API返回值的幽默编程之旅
运维·自动化
饮浊酒2 小时前
Linux操作系统 ------(3.文本编译器Vim)
linux·vim
lihuhelihu2 小时前
第3章 CentOS系统管理
linux·运维·服务器·计算机网络·ubuntu·centos·云计算
哲讯智能科技2 小时前
SAP Business One市场价格解析
运维·sap·erp
矛取矛求2 小时前
Linux系统性能调优技巧
linux
山东布谷科技官方2 小时前
布谷直播源码部署服务器关于数据库配置的详细说明
运维·服务器·数据库·直播系统源码·直播源码·直播系统搭建·直播软件开发
One_Blanks2 小时前
渗透测试-Linux基础(1)
linux·运维·安全