跳至主要内容

linux 学习

https://linuxtools-rst.readthedocs.io/zh_CN/latest/index.html



Linux 常用命令全拼






unix 时间戳是什么?

unix 时间戳是以运行总秒数来跟踪时间的一种方法。这个计数从 1970 年 1 月 1 日 UTC 的 Unix Epoch 开始。因此,unix 时间戳只是特定日期和 Unix Epoch 之间的秒数。还应该指出(感谢本网站访问者的评论),无论你位于世界何处,这个时间点在技术上都不会改变。这对于计算机系统在线和客户端的动态和分布式应用程序中跟踪和分类过时的信息非常有用。



linux远程工具


WinSCP
是一个 Windows 环境下使用的 SSH 的开源图形化 SFTP 客户端。同时支持 SCP 协议。它的主要功能是在本地与远程计算机间安全地复制文件,并且可以直接编辑文件

PuTTY
是SSH和telnet客户端,最初由Simon Tatham为Windows平台开发。PuTTY是开源软件,可提供源代码,并由一群志愿者开发和支持。

eleteer
是一个跨平台的Terminal / SSH / SFTP客户端工具,同时支持Linux,MacOS,Windows,基于electron / ssh2 / node-pty / xterm / antd / subx等开源组件。

以下为付费
Xshell
业界最强大的SSH客户机

MobaXterm
带有X11服务器,选项卡式SSH客户端,网络工具等的Windows增强型终端

FinalShell
http://www.hostbuf.com/
是一体化的的服务器,网络管理软件,不仅是ssh客户端,还是功能强大的开发,运维工具,充分满足开发,运维需求.


网络配置将由网络管理器(nmcli&nmtui)控制
以及centos8中去除的Network Scripts files(ifcfg-*)

cat /etc/sysconfig/network-scripts/ifcfg-ens33

判断网络是否连通
curl http://myip.ipip.net

yum update版本回退
如何在CentOS / RHEL服务器上使用yum history命令回滚更新
让我们获取用于更新的交易ID
yum history list all

使用下面的yum命令来查找根据交易ID实际更新的内容
yum history info ID

版本回退
yum history undo ID

cron

Crontab语法生成器
https://crontab-generator.org/
https://www.freeformatter.com/cron-expression-generator-quartz.html

cron工具允许Linux用户在特定的日期和时间执行命令或脚本。执行常规任务(例如常规备份,每日扫描,/ tmp目录清理以及在给定时间重新启动系统)非常有用。

所有cron jobs 都存储在/var/spool/cron(对于RHEL和CentOS发行版)和/var/spool/cron/crontabs(对于Debian和Ubuntu发行版)中,
cron jobs 使用创建该文件的用户的用户名列出
ll /var/spool/cron

cron daemon 在后台静默运行,检查/etc/crontab文件以及/var/spool/cron和/etc/cron.d*/目录

Linux crontab具有六个字段,前五个字段(1-5)指示执行的日期和时间,第六个字段用于执行命令或脚本
 .-----------------> Minute (0-59)
 |    .--------------> Hour (0-23)
 |    |    .-----------> Day of Month (1-31)
 |    |    |    .--------> Month (1-12) or (jan,feb,mar,apr ...dec)
 |    |    |    |    .-----> Day of Week (0-6) (Sunday=0 or 7) or (sun,mon,tue,wed,thu,fri,sat)
 |    |    |    |    |    .--> Command to be executed
 |    |    |    |    |    |
 *    *    *    *    *    *
MIN HOUR  DOM  MON  DOW  CMD

重要的cron命令,这些命令可以帮助用户轻松管理cron

corntab -e     # 编辑器中打开crontab文件,并允许用户在其中添加或删除条目
corntab -l     # 列出已登录用户的crontab条目
corntab -r    # 删除登录用户的crontab条目
corntab --help

cron守护程序的重要文件

# crontab配置文件
cat /etc/crontab  

# 可以在以下位置找到所有用户的crontab文件。
ls -lh /var/spool/

# 预定义crontab目录
/etc/cron.d 
/etc/cron.daily 
/etc/cron.hourly 
/etc/cron.monthly 
/etc/cron.weekly
/etc/cron.deny

# 允许的crontab特殊字符
+-------+----------------------------------------------------+
| Value |                     Description                    |
+-------+----------------------------------------------------+
|   *  | Match all possible values in the field             |
|   -   | To define a range                                  |
|   /   | To repeat an event at a specific interval          |
|   ,   | To separate a items                                |
+-------+----------------------------------------------------+




根据 Linux 惯例,字母d是守护进程(daemon)的缩写。 Systemd 这个名字的含义,就是它要守护整个系统。
Systemd 可以管理所有系统资源。不同的资源统称为 Unit(单位)。Unit 一共分成12种:

Service unit:系统服务、
Target unit:多个 Unit 构成的一个组、
Device Unit:硬件设备、
Mount Unit:文件系统的挂载点、
Automount Unit:自动挂载点、
Path Unit:文件或路径、
Scope Unit:不是由 Systemd 启动的外部进程、
Slice Unit:进程组、
Snapshot Unit:Systemd 快照,可以切回某个快照、
Socket Unit:进程间通信的 
socket、Swap Unit:swap 文件、
Timer Unit:定时器

每一个 Unit 都有一个配置文件,告诉 Systemd 怎么启动这个 Unit 。
Systemd 默认从目录/etc/systemd/system/读取配置文件。但是,里面存放的大部分文件都是符号链接,指向目录/usr/lib/systemd/system/,真正的配置文件存放在那个目录

systemctl enable 命令用于在上面两个目录之间,建立符号链接关系。
enabled:已建立启动链接
disabled:没建立启动链接
static:该配置文件没有[Install]部分(无法执行),只能作为其他配置文件的依赖
masked:该配置文件被禁止建立启动链接



如何在CentOS和RHEL中启用或设置EPEL存储库
EPEL代表“Extra Packages for Enterprise Linux”
顾名思义,epel为RHEL,CentOS,Scientific Linux(SL)和Oracle Enterprise Linux(OLE)提供了其他rpm软件包。EPEL由Fedora社区创建和维护,EPEL软件包是100%免费/自由的开源软件(FLOSS)。

对于CentOS 7.X / RHEL 7.X
以root用户打开终端执行以下命令
yum install epel-release
注意:EPEL存储库文件位于“/etc/yum.repos.d/epel.repo”下

列出新的存储库
yum repolist
获取包信息
yum info htop
从epel repo安装软件包
yum install htop


https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/7/
红帽

大多数服务器默认都会启用某些服务。这些服务可以允许您利用服务器上的多种功能,但是,如果没有利用这些额外的服务,则最好将其禁用
list-unit-files”向您显示了文件系统上实际存在的所有单位文件(无论是服务文件,套接字文件等),无论是否加载
systemctl list-unit-files --type=service | grep enabled
运行
systemctl | grep running
禁用服务
systemctl disable bluetooth

更新对于确保系统的安全至关重要,一个shell脚本,指示yum更新通过cron找到的所有软件包:
vi  /etc/cron.daily/yumupdate.sh
#!/bin/bash
YUM=/usr/bin/yum
$YUM -y -R 120 -d 0 -e 0 update yum
$YUM -y -R 10 -e 0 -d 0 update

第一个命令将自己更新yum,下一个命令将应用系统更新。
-R 120:设置yum在执行命令之前等待的最长时间
-e 0:将错误级别设置为0(范围0 – 10)。 0表示仅打印必须告知您的严重错误。
-d 0:将调试级别设置为0 –增大或减小打印的内容。 (范围:0 – 10)。
-y:假设是; 假设将要回答的任何问题的答案是肯定的。

确保您设置了可执行权限:
#chmod + x /etc/cron.daily/yumupdate.sh


chage命令列出并更改Linux用户帐户的密码过期信息
chage -l命令列出了用户的特定信息
chage -l user
chage -M命令修改了密码再次过期之前的天数值
chage -M 90 user


退出telnet
先打转义字符'^]'即CTRL+] ,再打quit

过滤空行和注释,并显示行号

E:正则,n:显示行号,v:反转
grep -Env "^$|#" config_file


查看cpu、内存、使用情况: vmstat n m (n 为监控频率、m为监控次数)
内存使用量 $free -m
查看磁盘空间 df -h
查看目录大小 du -sh
打包 tar -cvf
解包 tar -xvf
压缩 gzip

解压缩 ungzip bzip


查询正在运行的进程信息
$ps -ef

Linux 查看端口占用情况可以使用 lsof netstat 命令
lsof(list open files)是一个列出当前系统打开文件的工具
lsof -i:端口号
lsof -i:8080:查看8080端口占用进程状态

netstat
用于显示 tcp,udp 的端口和进程等相关情况
netstat -tunlp | grep 端口号

netstat -ntlp   //查看当前所有tcp端口

netstat -ntulp | grep 80   //查看所有80端口使用情况
netstat -ntulp | grep 3306   //查看所有3306端口使用情况

kill
在查到端口占用的进程后,如果你要杀掉对应的进程可以使用 kill 命令:
杀死指定PID的进程 (PID为Process ID)
$kill PID
杀死相关进程
kill -9 PID

使用命令pmap,来输出进程内存的状况,可以用来分析线程堆栈

$pmap PID


类型  文件描述符 默认情况   对应文件句柄位置
标准输入(standard input) 0 从键盘获得输入 /proc/self/fd/0
标准输出(standard output) 1 输出到屏幕(即控制台) /proc/self/fd/1
错误输出(error output) 2 输出到屏幕(即控制台) /proc/self/fd/2


shell命令将不会输出任何信息到控制台,也不会有任何信息输出到文件中
>/dev/null 2>&1

作用就是让标准输出重定向到/dev/null中(丢弃标准输出),然后错误输出由于重用了标准输出的描述符,所以错误输出也被定向到了/dev/null中,错误输出同样也被丢弃了

参考

nohup结合
我们经常使用nohup command &命令形式来启动一些后台程序,比如一些java服务:
# nohup java -jar xxxx.jar &

为了不让一些执行信息输出到前台(控制台),我们还会加上刚才提到的>/dev/null 2>&1命令来丢弃所有的输出:
# nohup java -jar xxxx.jar >/dev/null 2>&1 &


查看文件内容:cat vi head tail more
目录的创建、删除、移动、复制: mkdir rm mv cp
文件的查询: find
管道和重定向:  ;  | &&  || >

wc 统计行和字符的工具
$wc -l file // 统计行数
$wc -w file // 统计单词数
$wc -c file // 统计字符数


给文件增加别名 创建符号链接/硬链接:
ln -s cc ccTo :符号链接(软链接);删除源,另一个无法使用;(后面一个ccTo 为新建的文件)
ln cc ccAgain :硬连接;删除一个,将仍能找到;


 管道和重定向
| 批处理命令连接执行
;  串联使用分号
&& 前面成功,则执行后面一条,否则,不执行
|| 前面失败,则执行后一条

ls /proc && echo  suss! || echo failed.
与上述相同效果的是:
if ls /proc; then echo suss; else echo fail; fi

查找record.log中包含AAA,但不包含BBB的记录的总数:
cat -v record.log | grep AAA | grep -v BBB | wc -l


awk   文本处理工具 数据流处理工具
echo -e "line1\nline2" | awk 'BEGIN{print "start"} {print } END{ print "End" }'


sed 查找更改 文本替换利器
echo this is a text | sed -i 's/text/repalce_text/g'

默认替换后,输出替换后的内容,如果需要直接替换原文件,使用-i
sed -i 's/text/repalce_text/g' file

cut 过滤字段




dmesg
被用于检查和控制内核的环形缓冲区,kernel会将开机信息存储在ring buffer中。您若是开机时来不及查看信息,可利用dmesg来查看,开机信息保存在/var/log/dmesg文件里。

vimtutor
进入VIM教程

top
Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器

ll /proc/pid/exe
通过top查到进程的pid去定位程序目录

rpm -qf /bin/ps
查询/bin下的命令属于哪个rpm包,然后用yum install xx在线安装一个新的


lsof -R | grep "/usr/bin"
lsof(list open files)是一个查看当前系统文件的工具

chattr +i /etc/resolv.conf
chattr命令防止系统中某个关键文件被修改


了解Linux / etc / passwd文件格式

Linux用户信息位于/ etc / passwd文件中。
这是一个文本文件,其中包含有关每个用户的基本信息,每行包含七个字段
系统中的所有用户都可以在任何文本编辑器的帮助下读取它
ls命令来检查/etc/passwd 文件的权限。

/etc/passwd中的每一行代表一个用户。该文件将用户信息分为三部分
第一部分是root帐户,它是管理员帐户,具有对系统各个方面的完整控制权。
第二部分后面是正确安装和更新系统软件所需的系统定义的组和帐户。
最后的第三部分代表使用该系统的真实人员

创建新用户时,将修改以下四个文件。

/etc/passwd: 用户详细信息将在此文件中更新。
/etc/shadow: 用户密码信息将在此文件中更新。
/etc/group: 该文件中将更新新用户的组详细信息。
/etc/gshadow: 组密码信息将在文件中更新新用户

/etc/passwd文件将每个用户详细信息包含在一行中,每个行包含七个字段,如下所述,每个字段由冒号“:”分隔
Username:Password :User ID:Group ID:User ID Info:Home Directory:shell
例如 postfix:x:89:89::/var/spool/postfix:/sbin/nologin

以下是有关这七个字段的详细信息。
Username (postfix):创建用户的用户名。字符长度应在1到32之间。
Password (x):它表示已加密的密码存储在/etc/shadow文件中。
User ID (UID-89):它指示每个用户应包含唯一UID的用户ID(UID)。UID(0-Zero)为root保留,UID(1-499)为系统用户保留,UID(500-999)为系统帐户/组保留
Group ID (GID-89): 它指示每个组应包含的唯一组ID(GID),唯一的GID存储在/etc/group文件中。
User ID Info ():它指示注释字段。该字段可用于描述用户信息。
Home Directory (/var/spool/postfix): 它指示用户的主目录。
shell (/sbin/nologin): 它指示用户的bash shell。


想打印普通用户及其UID(从1000开始的UID)
cat /etc/passwd | grep /home | cut -d":" -f1,3 | sed 's/:/ /g' | column -t

允许用户更改自己的密码
只需使用ls命令来检查/ etc / passwd 文件的权限
ls -lh / etc / passwd

这可以通过Sticky Bit向passwd脚本文件分配权限来实现
ls -lh / bin / passwd 
粘性位主要用于共享目录。它允许用户创建自己的文件,读取,写入和执行其他用户拥有的文件,但不允许删除其他用户拥有的文件


1.history命令

history命令可以查看历史命令


2.history的用法

语法:

history: history [-c] [-d 偏移量] [n] 或 history -anrw [文件名] 或 history -ps 参数 [参数...]

    显示或操纵历史列表。

    

    带行号显示历史列表,将每个被修改的条目加上前缀 `*'。

    参数 N 会仅列出最后的 N 个条目。

    

    选项:

      -c        删除所有条目从而清空历史列表。

      -d 偏移量 从指定位置删除历史列表。

    

      -a        将当前绘画的历史行追加到历史文件中

      -n        从历史文件中读取所有未被读取的行

      -r        读取历史文件并将内容追加到历史列表中

        中

      -w        将当前历史写入到历史文件中

        并追加到历史列表中

    

      -p        对每一个 ARG 参数展开历史并显示结果

        而不存储到历史列表中

      -s        以单条记录追加 ARG 到历史列表中

    

    如果给定了 FILENAME 文件名,则它将被作为历史文件。否则

    如果 $HISTFILE 变量有值的话使用之,不然使用 ~/.bash_history 文件。

    

    如果 $HISTTIMEFORMAT 变量被设定并且不为空,它的值会被用于

    strftime(3) 的格式字符串来打印与每一个显示的历史条目想关联的时

    间戳,否则不打印时间戳。

    

    退出状态:

    返回成功,除非使用了无效的选项或者发生错误


3.history的历史命令保存文件

history默认保存1000条历史命令。历史命令保存在家目录下的 .bash_history 。

1000条历史命令的规则设置在 /etc/profile 的 HISTSIZE 的变量里。

通过 echo $HISTSIZE 可以查看保存的历史命令条数。


4.定义历史命令的执行时间

在 /etc/profile 里面定义一个变量 HISTTIMEFORMAT 并在后面加上时间格式的参数。

# vim /etc/profile

HISTTIMEFORMAT="%Y/%m/%d %H:%M:%S "

HISTSIZE=1000


# source /etc/profile

# history

699  2017/09/30 16:46:05 source /etc/profile

700  2017/09/30 16:46:29 history


5.永久保存所有的历史命令

给 ~/.bash_history 加一个特殊的a权限,就不能对文件进行删除的操作了。

# chatty +a ~/.bash_history


6.快捷命令的使用

!!:上一条命令

!n:n为数字,history的序列里的第n条命令,

!cmd:最近一次cmd这个命令开头的命令

评论

此博客中的热门博文

自动发送消息

  # https://pyperclip.readthedocs.io/en/latest/ import pyperclip while True :     # pyperclip.copy('Hello, world!')     # pyperclip.paste()     # pyperclip.waitForPaste()     print ( pyperclip. waitForNewPaste ( ) )     # 获取要输入新的坐标,也可以通过autohotkey import time import pyautogui  as pag import os   try :     while True :         print ( "Press Ctrl-C to end" )         x , y = pag. position ( )   # 返回鼠标的坐标         posStr = "Position:" + str ( x ) . rjust ( 4 ) + ',' + str ( y ) . rjust ( 4 )         print ( posStr )   # 打印坐标         time . sleep ( 0.2 )         os . system ( 'cls' )   # 清楚屏幕 except KeyboardInterrupt :     print ( 'end....' )     # 打印消息 import pyautogui import time import pyperclip   content = """   呼叫龙叔! 第二遍! 第三遍! 第四遍...

学习地址

清华大学计算机系课程攻略 https://github.com/PKUanonym/REKCARC-TSC-UHT 浙江大学课程攻略共享计划 https://github.com/QSCTech/zju-icicles https://home.unicode.org/ 世界上的每个人都应该能够在手机和电脑上使用自己的语言。 http://codecanyon.net   初次看到这个网站,小伙伴们表示都惊呆了。原来代码也可以放在网上卖的?!! 很多coder上传了各种代码,每个代码都明码标价。看了下销售排行,有的19刀的卖了3万多份,额di神啊。可以看到代码的演示效果,真的很漂亮。代码以php、wordpress主题、Javascript、css为主,偏前台。 https://www.lintcode.com/ 算法学习网站,上去每天刷两道算法题,走遍天下都不怕。 https://www.codecademy.com/ 包含在线编程练习和课程视频 https://www.reddit.com/ 包含有趣的编程挑战题,即使不会写,也可以查看他人的解决方法。 https://ideone.com/ 在线编译器,可运行,可查看代码示例。 http://it-ebooks.info/ 大型电子图书馆,可即时免费下载书籍。 刷题 https://github.com/jackfrued/Python-100-Days https://github.com/kenwoodjw/python_interview_question 面试问题 https://github.com/kenwoodjw/python_interview_question https://www.journaldev.com/15490/python-interview-questions#python-interpreter HTTP 身份验证 https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Authentication RESTful 架构详解 https://www.runoob.com/w3cnote/restful-architecture.html https://www.rosettacode.org/wiki/Rosetta_C...

mysql 入门

资料 https://dinfratechsource.com/2018/11/10/how-to-install-latest-mysql-5-7-21-on-rhel-centos-7/ https://dev.mysql.com/doc/refman/5.7/en/linux-installation-yum-repo.html https://www.runoob.com/mysql/mysql-create-database.html https://www.liquidweb.com/kb/install-java-8-on-centos-7/ 工具 https://www.heidisql.com/ HeidiSQL是免费软件,其目标是易于学习。 “ Heidi”使您可以从运行数据库系统MariaDB,MySQL,Microsoft SQL或PostgreSQL的计算机上查看和编辑数据和结构 MySQL 连接时尽量使用 127.0.0.1 而不是 localhost localhost 使用的 Linux socket,127.0.0.1 使用的是 tcp/ip 为什么我使用 localhost 一直没出问题 因为你的本机中只有一个 mysql 进程, 如果你有一个 node1 运行在 3306, 有一个 node2 运行在 3307 mysql -u root -h localhost -P 3306 mysql -u root -h localhost -P 3307 都会连接到同一个 mysql 进程, 因为 localhost 使用 Linux socket, 所以 -P 字段直接被忽略了, 等价于 mysql -u root -h localhost mysql -u root -h localhost 而 -h 默认是 localhost, 又等价于 mysql -u root mysql -u root 为了避免这种情况(比如你在本地开发只有一个 mysql 进程,线上或者 qa 环境有多个 mysql 进程)最好的方式就是使用 IP mysql -u root -h 127 .0 .0 .1 -P 3307 strac...