经验拾忆(纯手工)=> Linux实用工具命令

Ubuntu16升级到18.04

“”“
    有特殊新颖强迫症癖好可以升下,如果你觉得16.04好用,就根本没必要升了
”“”
我当时租的 云服务器通常都是16.04,现在估计也是16.04较多
我是个Python3的玩家, 我只想用Python的最新版,或最新标准版3.6-3.7
道理很简单,我追求新颖,虽然新版不稳定,但是你可以尝鲜并领先于别人。。。
废话不多说:
    Ubuntu16.04: 默认装的是Python2.7 + Python3.4 或3.5 
    Ubuntu18.04: 默认装的是Python2.7 + Python3.6.+
我喜欢升级系统版本来直接让对应软件升级:
    lsb_release -a    # 查看系统版本
    apt update        # 一路选Y   
    apt dist-upgrade  
    apt autoremove    # 一路选Y
    apt install update-manager-core    # 比较重要
    do-release-upgrade -d              # 完事
注:
    如果其中某个命令过程弹出一个黑窗口让你选择, 我记得有个 
        core-new-update 字眼的,选这个即可    # 选择 新 核心

vim多行注释(Python为例)

Ubuntu是肯定可以用, CentOS我记得好像用不了

直接一套连招:
注释:
    1. ctrl + v
    2. 按 下 箭头方向键,选中多行
    3. shift + i
    4. 输入 # 
    5. 按两下 ESC键
    
取消注释:
    1. ctrl + v
    2. 按 下 箭头方向键,选中多行
    3. 按 x 键

注: 此套连招,需要熟练度, 如果不行就多练练。 手不好使,就不要怪我了~~~~
    

vimrc简单配置:

“”“
    tab = 4缩进,
    设置行号
    基于文件名的简单语法高亮
    不要想着删一行,直接打开vimrc 全部复制上去,保存退出就可以用了
”“”
vi ~/.vimrc
    syntax on
    set nu
    set expandtab
    set tabstop=4
    set shiftwidth=4
    set softtabstop=4

locate查询库

locate xxx    # 虽然很简单的命令,但是如果,一直为下线,并且还想查找新东西,那么需要更新库
updatedb      # 更新搜索库, 完事

如果 updatedb命令出错,那就安装一下 mlocate就好了:
    yum/apt-get install mlocate

htop查看服务器负载

ubuntu/centos中有 
    top : 此命令可以详细查看服务器各种负载,资源状况,但是看着不方便,非常费劲
    htop : top的升级版, 容易看出资源消耗情况
    如果未安装,可通过  
        apt-get/yum install htop   安装

    htop -d 0.1    # 0.1秒动态更新一次资源数据。 看起来有一点炫。
    

pkill

ps -el 查看 PId + kill -9 PID        # 这套连招可强制杀死一个进程

但假如你有一连串的python进程 想要 全部KILL
    pkill python            # 完事,和python有关的全KILL掉了,也可以通过通配符* 的方式来简写

patree列出进程

tree:    此命令用来列出目录层级结构
pstree:  用来列出 正在运行的 程序(所有进程的层级结构,进程名)
pstree -p: 以层级的方式,不仅列出进程名, 还列出所有进程的(PID)

alias改名

vi /etc/profile
    alias python='python3'        # 这里是举个例子,配完,python命令就等价于 python3命令
    alias pip='pip3'
source /etc/profile            # 不要忘记,这条命令 更新一下配置文件

重定向管道 ( > 与 tee )

date > date.txt         # 截流, 屏幕上不显示
date | tee date.txt  # 不截流, 屏幕上显示, 并且还能输入到文件

! 叹号命令

”“
    !命令前缀 : 运行最后一条以这个前缀开头的命令
”“
假如下面是你最后按顺序再command终端 输入的四条命令:
    python aaa.py
    python bbb.py
    npm run dev
    pip install ccc

需求:你想迅速运行 python bbb.py这条命令
你只需
    !py    # 即可,  愣着干啥呢, 已经完事了,这条命令就等于你上面那一大串
    
    解惑:
        1. !py   -> py开头的有两条,为啥不执行第一条 python aaa.py
            因为 ! 叹号 的语法意思就是选择 最后出现以py开头的执行。
        2. 为啥直接 !p 不行呢?
            因为以p开头的最后一条命令是 pip install ccc。  这也不是你想要的啊。

ctrl+z 和 & 和 nohup 和 screen

ctrl+c: 强制终止(最常用的,先提出来。。。。 应该都知道的。。)
ctrl+z: 可以把正在运行中的程序挂起到后台(注意这时候程序就暂停了)
jobs:    粗略列出 后台挂起的程序
jobs -l: 详细列出 后台挂起的程序 (其实就是多列出了个PID)
         kill -9 PID   # 顺水推舟地使用此命令来通过 PID 干掉后台挂起的程序
    
fg:      把挂起的后台的程序 拿回来继续执行
fg 程序编号:  如果有多个后台挂起的程序,选择一个继续执行,编号可通过 jobs 查看。

使用场景: 
    加入正在 vim 编辑东西,想跳出编辑器,写点别的,那么可以 进行下面操作:
    不要保存, 直接 ctrl+z
    然后去 做别的事
    做完了想回到 vim继续编辑剩下的内容, 直接 fg
    
&: 运行 的 时刻 就直接 放到后台  (不实用)
    eg: (通常是费时的操作,或者长时间占用 command命令行)
        sleep 100 &        # 这样费时100秒的操作,直接让它滚去后台执行,别占我地方
    局限:
        假如你用  python xxxx.py & 运行一个web服务器,虽然它会滚去后台一直运行。
        前台command界面看起来很干净了。
        但是,如果有用户请求过来, 你服务器收到打印在终端的信息 可不会乖乖打印在后台。
        打印信息会钻出来到前台command界面来恶心你。。。。。
        为了解决这一问题, 请移步 下面 ...

nohup: (通常和 上面的 & 联合使用)     (实用性一般)
    eg: 同样运行一个服务器
        nohup python xxx.py &        
            #  它会乖乖的滚去后台执行,并且将要打印的消息 也不会打印到前台,也不会打印到后台。
                那打印的内容去哪了呢??
                nohup会自动给你 把打印的东西重定向 到一个  nohup.out文件,通常在当前目录下
            #  这时你的前台command 就不会受到 骚扰了。。。。
    也许你以为它很好用了,可以完美的决绝运行一个费时的进程。但是 它依然是个 loser。。.
    局限:
        当我一直用 nohup.out 部署一些服务程序的时候,一部署就是很多天。
        当时学校断电(我租的阿里云ECS服务器). 虽然服务器可以不间断的执行。
        但是 我需要 用 xshell 一直去远程 查看我的 程序运行的怎么样了啊, 是否崩了?
        可惜的是,每次xshell关闭了,你再上去, 想找 通过 nohup & 连招 放到后台程序的时候,
        你会痛苦无比。。。非常惨
        后来。。。。。。。。。
        
screen: (会话机制)  
    没错,后来我就发现了 这个 screen工具 
    如果你那里没有,就安装一下喽:  apt-get / yum install screen 
    然后需要配置一下:
        vi ~/.screenrc       # 创建文件        
            shell -$SHELL    # 输入此行内容,保存退出
    至于为何配置这个: 说实话我有点忘了
        貌似不同screen会话对于不同的shell 权限有限制,导致很多东西用不了,so do it
    
    直接说一套我常用且超级实用连招把:
    eg:
        screen -S 会话名       # 创建 并 进入这个会话(就像进入另一个世界,但资源共享)
        python xxx.py         # 举例子,这是我的爬虫程序,需要运行 三天
        ctrl + a + d          # 跳出会话,回到正常命令行,但是这个会话以及你的程序依然在运行,
        ....... 这段时间(除了关闭服务器)你做什么都行,关闭 shell也可以的。
        screen -r 上面的会话名    # 恢复到会话中,  你会发现,爬虫程序还在那里好好的运行呢。
        
        如果你忘记会话名了,不要紧:
        screen -ls     # 这条命令会列出所有 你创建过的会话,你也可以看到会话名
        
    总结:
        所以,我不知道阁下能不能感受到 screen的魅力。
        我们可以 通过  screen -r 这一条命令来 迅速回到程序运行的环境。
        nohup &: 你用这个执行的程序,关了 xshell, 你再连,你就不好找这个运行的程序了
        screen 有一套完好的系统(就像有开关一样)来控制会话
               你进入screen会话中写程序,screen 自然就能有条不紊的管理好 你程序的运行状态

        举个白话例子:
            你正遛二哈呢,突然有急事:
            nohup & :  你说:‘二哈,等我回来,自己玩把’        
                       你回来时, 二哈跑丢了。 (不受控制,程序找不到了,虽然可以花力气找到)
            screen  :  你说:‘二哈,等我回来,自己玩吧,但我要把你拴起来’        
                       你回来时, 二哈还在那里乖乖的玩。(程序有效的受到控制,你可以轻松定位)

sudo su等操作

不好意思,用了好几年linux:
    什么 su- su 之类的,  我至今都没搞太明白。。。。。。。。。。

但是,我只用下面这一条命令,这些年就没遇到过问题:
    sudo -s    # 变为root, 如果你之前输入过密码, 这条命令还会免去让你输入密码的环节

环境变量

把某路径加入到环境变量中:
    vi /etc/profile
        export PATH=$PATH:/XXX/XX

做一些配置:
    vi /etc/profile            
    vi ~/.bashrc 
    等修改完后
    source /etc/profile        # 用一个 source 命令执行一下使配置更新生效
    
注: Linux-shell我研究的不深,所以这里可能有些说的不是特别明朗。
    其实 这些配置文件 以及 source . sh bash 这些命令 和 用户 以及权限等都是有很大关系的。   
    有兴趣可自行深入了解

激活Ubuntu的root用户

也许你ubuntu只能用root权限
但你不能使用root用户登录,或不能使用root用户进行ssh连接
ubuntu其实是存在 root 用户的, 不用创建,给个密码就能直接使用
sudo passwd root

root用户远程SSH连接

假如你的 xshell 连接不上远程服务器, 可能未开启 或 未安装 sshd服务
如下命令即可:
    sudo apt-get install ssh
    systemctl start ssh
如果你想要用root用户直接ssh连接, 可作如下配置:
    sudo vim /etc/ssh/sshd_config
        PermitRootLogin yes
    systemctl restart ssh
    

MySQL5.7+/MariaDB修改密码小坑

当阁下还在停留在Mysql5.7版本之前,修改密码可以用下面这两种方式:
    mysqladmin -uroot password -p
    或内部设置:
    update user set password=password('root') where user='root'

但是 MySQL5.7 之后 或者 MariaDB ,上面这俩方法 都不能 修改密码了。
正确修改方式:
    先进入MySQL交互式: MySQL -uroot -p 

    update mysql.user set authentication_string=password("密码") where user="用户名"
    update user set plugin="mysql_native_password";
    flush privileges
    
    最后重启服务, 完事
    
另外,值得提醒的一点容易出现的问题:
    无论你连接的是什么数据库,如果你连不上
    
    首先你应该想到的是,数据库配置文件:
        bind 0.0.0.0        # 每种数据库几乎都需要先改成这样,才能被外界访问
        
    其次,你用的是云服务器的话
        看看是否放通了 对应数据库的宽口
        
    最后,是否开了防火墙:
        没记错的话,Centos 和 Ubuntu 防火墙不是同一种,真正需要关闭可自行百度
        

其他命令

"""
    一时间也记不起来还用过哪些了
"""

wc             : 统计字,词,行(自己选参数)
curl           : 可以请求 url,并返回数据(相当于一个小小爬虫),也可以向某个接口发送请求
ssh-keygen     :生成公私密钥
cd -           : 跳回到上一次的路径
lsb_release -a : 查看Linux发行版信息
grep           : 过滤字符
tar            : 压缩/解压
netstat        : 查端口
等
    原文作者:Cython_lin
    原文地址: https://segmentfault.com/a/1190000019714866
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞