Unix_Linux_AIX_常用命令总结

2024-03-04 07:58

本文主要是介绍Unix_Linux_AIX_常用命令总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

■Java常用知识总结

■前言 (常用链接)

・Shell 自动化 处理相关 需要使用到的命令

■编码思想

■编码规范

■shell脚本

■循环处理

1.循环小火车

2.循环cup性能

■各种命令

0.cd 

1.uname

2.ifconfig

3.who

4.chown

5.chmod

6.cp

7.tail     

8.head

9.grep

10.view

11.1.cat

11.2.less 分页查看文件

11.3.more 查看文件

12.clear

13.reset

14.free

15.df

16.du

17.pwd

18.passwd

19.man

20.tar 

21.ls

22.ps

查看进程中的线程

查看服务

ps aux 和ps -elf 区别

ps -ef 和 ps -elf 在显示时的区别,举个例子

23.chsec

24.sed

25.locate

26.cal

27.mkdir

28.touch

29.rm

30.vi

31.特殊符号之【`】 不是单引号 (是反单引号)

32.特殊符号之【&】 

33.sudo

34.su

35.log设定(Tera Term)

36.ll (只限Linux中使用)

37.id

38.特殊符号之 【$()】

39.dirname

40.find

4.查找文件夹下,哪些文件,含有某字符

6.find 参数 mtime

41.history

42.1.md5sum fileName

42.2.sum fileName

43.systemctl

44.wc

45.hexdump

46.xargs

47.vmstat

47.umask

48.mv 

49.jq

50.SUID   SGID

51.usermod

52.访问权限说明

53.gpasswd

54.adduser 创建用户

55.grpup  .passwd   .sudoers

   查看所有组, 所有用户,sudo权限

56.kill

57.awk

58.| 管道(|)    (パイプ  管道 pite)

59.echo

60.其他用户修改文件后,对文件所属,组的影响

61.tee

62.查看系统・用户信息

63.chage -l yourUserName

64.ssh

65.function

66.unzip

67.zip

68.diff

69.scp 获取远程文件

70.screenfetch 显示系统信息

71.sl 小火车

72.cmatrix:黑客帝国

73.特殊符号【./】

74.netstat

74.1.netstat、rmsock  (AIX)

75.cron

76./dev/null

77.nohup

78.lsof

79.ln

​编辑80.unlink  解除软连接

81.which

82.特殊符号【"】(双引号)  与【'】单引号

83.符号【&&】、【||】

84.basename

85.gunzip

86.locale // 命令

87.LANG // 系统变量  // Language的缩写

88.安装语言包・查看默认语言设置

89.showmount

90.Linux的shell命令,直接在终端执行。

91.特殊符号【{}】 大括号

92.gzip

93.mount

94.unmount

95.iconv

96.tcpdump

97.★★★ 实际应用  ★★★ 【if else】【字符串包含】【字符串比较】

96.time  查看命令性能 (不同于 windows 的time)

97.locale

98.native2ascii    (转换 \uXXXX  unicode )

99.zcat

100.perl

101.curl

https认证使用

登录使用

指定客户端证明书

参数 m 指定超时等待时间

curl的错误类型

102.set

103.openssl

导出公钥(证书)(crt)

导出秘钥(key)

104.特殊符号【~】

105.sftp之参数【-b】

106.date

107.sh -xe 参数是什么意思

108.grep 查询不到时, 也能返回 0

109.base64

110.bc

111.known_hosts 中  ssh-rsa 的值 是根据什么生成的

112.如何查看主机的公钥信息

113.shell 中 ${0##*/} 是什么意思-----获取脚本文件的名称

114.hostname

115.printf

116.特殊符号【^M】【 ^!】 等等这些转义字符,以及其含义

117.XXX

118.XXX

119.XXX

■AIX

1.查看端口对应的进程 (Websphere Server)

2. shell  // AIX切换壳 

3.rm 删除文件

4.csum

5.find運用(AIX)

6.istat   查看文件最新修改时间

7.AIX 查看用户上一次登录・用户是否被锁

8.在 AIX 系统中,如果没有安装 unzip 命令,可以尝试使用以下命令解压缩 Zip 文件:

9.查看磁盘容量

10.查看字符对应的16进制编码 【od】 (linux 也能用) 

11.last【用于显示登录和注销的用户会话记录】

12.输出文件 无行换 (AIX ksh壳下面) 【\c】

13.nslookup  获取给定IP地址的服务器名称

14.prtconf 查看系统设置

15.【rmsock】 AIX根据端口号,查找PID

16.svmon 【AIX中 类似 Linux系统中 free 的命令】

17.【du】查看某个目录,容量占用多的文件夹

18.【df】查看===文件系统===的=磁盘===使用情况,百分比

19.LInux 的 du 和 dh 命令的区别

20.

21.

22.

23.

■其它

1.AIX 无法补全的原因

2.sh 与 ksh

以 #!/bin/ksh  开头

介绍几个 sh 与 ksh 语法之间的区别

■更多命令


======

■Java常用知识总结

Java8新特性学习_001_(Lambda表达式,函数式接口,方法引用,Stream类,Optional类)_sun0322的博客-CSDN博客

■前言 (常用链接)

  ・Unix,Linux 介绍 

  初次安装Linux(Ubuntu)(ssh,ftp服务安装)_sun0322-CSDN博客 (介绍内容在文章底部)

・ 自己的用户

自己的Linux用户_sun0322-CSDN博客

・ 常用目录 

  Linux中常用的目录(/home,/etc ,/opt)_sun0322-CSDN博客

・Linux服务器,性能测试相关

Linux系统性能相关知识学习_sun0322-CSDN博客

・Shell 自动化 处理相关 需要使用到的命令

shell自动化处理_相关知识整理(整理中)20210329_sun0322-CSDN博客

・TeraTerm相关操作

使用TeraTerm自带SSH SCP功能,传送文件_sun0322-CSDN博客

・硬链接(hard link)和软链接(soft link或symbolic link)

Linux系统中的硬链接(hard link)与软链接(symbolic link) - lemonning - 博客园

・ 更多命令

【Linux】一步一步学Linux系列教程汇总(更新中......)_嵌入式开发工程师---欢迎大家一起交流-CSDN博客_csdn dengjin

・ 常用bat命令

常用 doc bat 命令总结_sun0322-CSDN博客

・工作中使用的单词

https://blog.csdn.net/sxzlc/article/details/104872052

■编码思想

https://blog.csdn.net/sxzlc/article/details/116357487

每个命令行是个小工具,专注又单一,
但是可以通过管道的方式把他们连接起来,协同完成一个大任务,
这种设计理念是从一开始就植根到Unix当中的。 The UNIX Philosophy,提出了9条格言:
==============================一:小即是美。二:让程序只做好一件事。三:尽可能早地创建原型。四:可移植性比效率更重要。五:数据应该保存为文本文件。六:尽可能地榨取软件的全部价值。七:使用shell脚本来提高效率和可移植性。八:避免使用可定制性低下的用户界面。九:所有程序都是数据的过滤器。==============================

■编码规范

1.脚本格式要求
  ・脚本以#!/bin/bash开(关联(file):Linux中的file命令_sun0322-CSDN博客)
  ・脚本需要有可执行权限

             

2.Shell变量简介
  ・Linux Shell中的变量分为系统变量和用户自定义变量。
  ・系统变量:$HOME、$PWD、$SHELL、$USER等,比如echo $HOME
  ・显示当前shell中所有变量:set

3.shell变量的定义
(1)基本语法:
  ・定义变量:变量名=值
  ・撤销变量:unset 变量
  ・声明静态变量:readonly变量,注意,不能unset

(2)定义变量的规则:
  ・变量名称可以由字母、数字和下划线组成,但是不能以数字开头。
  ・等号两侧不能有空格
  ・变量名称一般习惯为大写,这是一个规范,遵守即可。

(3)将命令的返回值赋给变量
  ・NAME=`date`反引号,运行里面的命令,并将结果赋给变量NAME
  ・NAME=$(date)等价于反引号

■shell脚本

变量说明: 
$$ 
Shell本身的PID(ProcessID) 
$! 
Shell最后运行的后台Process的PID 
$? 
最后运行的命令的结束代码(返回值) 
$- 
使用Set命令设定的Flag一览 
$* 
所有参数列表。如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数。 
$@ 
所有参数列表。如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。 
$# 
添加到Shell的参数个数 
$0 
Shell本身的文件名 
$1~$n 
添加到Shell的各参数值。$1是第1参数、$2是第2参数…。

快速入门Shell脚本(1)——Shell脚本的介绍

快速入门Shell脚本(1)——Shell脚本的介绍_大数据记录-CSDN博客

快速入门Shell脚本(2)——系统变量与自定义变量

快速入门Shell脚本(2)——系统变量与自定义变量_大数据记录-CSDN博客

快速入门Shell脚本(3)——条件判断语句与循环

快速入门Shell脚本(3)——条件判断语句与循环_大数据记录-CSDN博客_shell 判断语句

https://blog.csdn.net/sxzlc/article/details/107926752 (私密)

快速入门Shell脚本(4)——常用的函数操作

快速入门Shell脚本(4)——常用的函数操作_大数据记录-CSDN博客

■登陆用户

 $表明是非root用户登录,#表示是root用户登录

   sudo su - 之后,会变成 #

■内部变量

Linux中 大写的$PWD 与小写的 pwd 之间的区别 (变量 与 命令 的区别)_sun0322-CSDN博客_$pwd

■vi

Linux中 Vi的使用_sun0322-CSDN博客

■权限

Linux 命令 之 【chmod】 修改文件权限~_sun0322-CSDN博客

■ls -l  每一列的含义

linux下 ls -l 命令显示结果每一列代表什么意思 - 码农编程进阶笔记 - 博客园

■ls -l  文件类型

linux下的7种文件类型[ls -l] - 夏天就该吃西瓜 - 博客园

■循环处理

1.循环小火车

for ((c=1;c<=10;c++)); do sl; sleep 3; done

---

while true; do sl; sleep 3; done

---

2.循环cup性能

Linux系统性能相关知识学习_sun0322的博客-CSDN博客

while true; do TIME=`date "+%H:%M:%S"`; CPU=`ps -aux | grep mysqld | grep -v grep | awk '{print $3}'`; MEM=`ps -aux | grep mysqld | grep -v grep | awk '{print $3}'`;echo "${TIME},${CPU},${MEM}";sleep 3; done

---

■各种命令

0.cd 

    目录跳转

1.uname

     uanme -a 显示服务器全部信息uname -n 显示服务器名字

===

2.ifconfig

     ifconfig -a  查看网络配置

3.who

     显示当前在线用户

4.chown

      chown root:webserver  修改文件的 → 所有者:用户组

5.chmod

     chomod -R 777 /XXX/XXX/*.sh  // -R 代表修改子文件夹中的内容chomod -R a+r  /XXX/XXX/*.shchomod 777 xxx.log

   Linux 命令 之 【chmod】 修改文件权限~_sun0322-CSDN博客

===

目录权限已经是744 其他用户仍不能访问目录

・对于一般文件
可读权限就是能够读取该文件的实际内容,
可写权限就是能够编辑、新增、修改文件的实际内容,
可执行则代表能够运行一个脚本程序的权限。・对于目录文件
对于目录文件的可读权限就是能够读取该目录内的结构和文件列表,
可写权限就是能够更改目录内文件结构列表、新增、删除、重命名文件,
而可执行实质是代表进入该目录的权限。

因此,对于文件,我们多设置为 644

对于文件夹,我们多设置为 755

(rwx)

===

   -R, --recursivechange files and directories recursively

6.cp

     cp -fp  /from/1.txt /to/1/txt   // preserve 保持文件属性 , force 覆盖

    -p 参数虽然可以保持属性,但是,有的时候,需要sudo do - 切换特权用户之后,才能有效。

         因为,如果不是特权用户的话,没有操作其他用户的权限,

          即使使用 -p参数复制,复制之后,并不能保持文件属性。

          文件的所有者和组信息,是登录用户的信息,不能保有原来的信息。

cp -r /AAA/BBB/CCC /home/user001

复制文件夹。把CCC这个文件夹,复制到 user001目录下面。 

在复制的时候,需要使用参数 -r 

7.tail     

     tail -n 500 xxx.log 显示文件最后500行,一般用于查看log

    ・tail -n

    tail -f /XXXXX/XXX/.log     //动态查看log信息

tail -f AAA.log  根据文件描述符进行追踪,当文件改名或被删除,追踪停止tail -F AAA.log  根据文件名进行追踪,并保持重试即该文件被删除或改名后,如果再次创建相同的文件名,会继续追踪
---
tail -F AAA.log | grep FIND_KEY_WORD

・tail -数字

tail 命令,下面两个效果相同

tail -n 3
tail -3
---
都是显示最后三行的意思

---

2022-12:grep '\"2021\-12' ./*.csv | tail -3 | xargs iconv -f sjis -t utf8
显示查询出的文件中,最后三个文件的内容。(查看文件时,把编码转换成utf8后打开)

8.head

显示文章前十行

 head -n 10 xxx.jsp

查看第一个,ERROR,以及其下面的30行

cat xxx.log | grep -30 ERROR | head -60 | tail -30

9.grep

     grep searchStr xxx.log  // 在log中查找字符串

9.1.  Linux中,支持正则表达式

       ls -l | grep "*.log"   // 查询不到内容

       ls -l | grep .log   // OK,可以查询到你想要的内容 

       ls -l | grep *.log   // OK,可以查询到你想要的内容 

9.2.  grep 中的 ^ 代表开头的意思

grep /bin/grep
grep -iv [指定字条串] [文件]
在文件中搜索字符串匹配的行并输出
-i 不区分大小写 -v 排除指定字符串grep -i java /etc/profilegrep -v ^# /etc/profile
不显示以#开头的行
要找出userIdList.csv文件中,A到H打头的行
grep '^[A-H]' userIdList.csv

※ 不同于 java 中的正则表达式 中的 ^,    java 中的 ^ 代表 排除的意思

[^abc] Any character except a, b, or c (negation) 

Java学习(更新中)_sun0322-CSDN博客

===============

9.3.  grep 中的 $ 代表结尾的意思

===============

9.4.1. grep -E "Batch[0-9]{3}W"
  按正则表达式查询,使用参数【-E】 
下面的第一行,第二行,OK, 3,4行NG,查询不出来内容

grep -E "Batch[0-9]{3}W"
grep -E Batch[0-9]{3}W
grep Batch[0-9]{3}W
grep Batch[0-9]{3}W

===============

9.4.2. grep -e "batch.jar$"

XXX_batch.jar // 抽出
XXX_batch.jar_bak_2020_1208 // 不会被抽出

grep -e "KEY1" -e "KEY2"  // 查询多个条件

keytool -list -v -keystore cacerts -storepass changeit | grep -e "XXX" -e "XXX"

外部系统连接SFDC,获取SFDC侧的数据_sun0322-CSDN博客

===============

9.5.grep -v 排除

9.6.・cat xxx.log | grep -1 yourkeyword

// 会把关键字所在的行,以及前一行,后一行,都显示出来

9.7.grep -Hn 显示文件和行数

9.8.文件名的显示

grep key  *.csv   // 显示文件名:内容 (即使不加H,也能显示文件名)

grep key  user.csv  // 不显示文件名 (想显示时,要加 H)

       

10.view

       view xxx.log

11.1.cat

      cat xxx.log

    // 可以在显示文件的时候,显示行号

root@sxzap01:/usr/local/tomcat/apache-tomcat-9.0.30/webapps/examples/jsp# cat -n index.html

    

  // 显示行号,可以配合grep一起使用

cat -n index.html | grep apache

cat 与 more 一起使用

//  比less多的效果, 显示后的内容,会残存在操作的界面中

cat -n index.html | more

11.2.less 分页查看文件

操作功能说明
空白键向下翻动一页
【pagedown】向下翻动一页
【pageup】向上翻动一页
/字串

向上搜寻【字串】的功能:n:向下查找;N:向上查找 

(补足说明:输入「/serchKey」之后,

     先按下回车,检索开始,再按N)

?字串向上搜寻【字串】的功能:n:向上查找;N:向下查找
q离开less这个程序

鼠标滚轮,可以一点一点翻页,使用起来非常方便

===

---

less -N index.html // 显示行号, 注意,是大写的 N

===

11.3.more 查看文件

操作功能说明
空白键(space)代表向下翻一页
Enter代表向下翻【一行】
q代码立即离开more ,不再显示该文件内容
Ctrl + F向下滚动一屏
Ctrl + B返回上一屏
=输出当前的行号
:f输出文件名和当前行的行号

more 直接 翻到 最后一页 大写的G (Shift + g)

more  n 继续向下查找
more  N 向上查找  (Shift + n)

====

12.clear

       清屏  // cmd中是cls

13.reset

       重新加载 // 查看class文件会乱码,之后一直乱码,使用reset可以解决

14.free

15.df

      df | grep ws 查看磁盘容量(每一个磁盘分区的使用情况)

Filesystem     1K-blocks    Used Available Use% Mounted on
udev             4041060       0   4041060   0% /dev
tmpfs             814496    1576    812920   1% /run
/dev/sda2       26700964 7634492  17687096  31% /
tmpfs            4072468       0   4072468   0% /dev/shm
tmpfs               5120       0      5120   0% /run/lock
tmpfs            4072468       0   4072468   0% /sys/fs/cgroup
/dev/loop1         91264   91264         0 100% /snap/core/8268
tmpfs             814492       0    814492   0% /run/user/1000
/dev/loop2         99328   99328         0 100% /snap/core/9665

 如果有使用其他 公用盘符的地方,可以通过 df 看出来

172.192.168.22:/DATA/XXX/XXX    ---------------    /DATA/XXX/XXX

1.1 查看磁盘空间的使用

 df -h

1.2 查看节点的使用 // 节点满了,同样会影响使用

 df -i

  linux磁盘爆满 linux df -i 100%处理_树叶咖啡厅-CSDN博客

16.du

      du -s websphere  显示每个文件 和 目录的磁盘使用空间(容量)

・查看指定目录下,每个包含sss的文件夹,所占用空间的大小

【查看磁盘容量】

find ./ -maxdepth 1 -type d | grep sss | xargs du -sh

---

cd /AA/UserGroup/
〇 find ./ -maxdepth 1 -type d | grep sss | xargs du -sh
// sss 是文件夹名字包含的内容。(sss001,sss002)× find ./ -maxdepth 1 -type d | xargs du -sh
// 无法看到每个文件夹,看到的是整体〇 find ./ -maxdepth 1 -type d
× find ./ -type d -maxdepth 1 // 有警告

---

・du与df的区别和联系

1.du,disk usage,是通过搜索【文件来】计算每个文件的大小然后累加df,disk free,通过【文件系统】来快速获取空间大小的信息2.du查看目录大小,df查看磁盘使用情况。

・usage 英 [ˈjuːsɪdʒ] n. 使用;用法;惯例

---

17.pwd

     查看当前路径

18.passwd

     ・变更密码

  ・查看密码锁定状态

# passwd -S YourUserID
pispread PS 2020-04-30 7 99999 15 -1 (Password set, SHA512 crypt.)(パスワード設定済み、SH512暗号化)用户锁定
# passwd -l pispread
Locking password for user pispread.
passwd: Success查看用户 // 只有 root 用户才能执行
# passwd -S pispread
pispread LK 2020-04-30 7 99999 15 -1 (Password locked.)用户解锁
# passwd -u pispread
Unlocking password for user pispread.
passwd: Success查看用户
# passwd -S pispread
pispread PS 2020-04-30 7 99999 15 -1 (Password set, SHA512 crypt.)

19.man

      查看命令帮助

       man 7 ascii

       可以查看ASCII 编码表

            Linux 下 ascii 的查看方式_https://space.bilibili.com/59807853-CSDN博客

20.tar 

tar -cvf etcbak.tar etc/         //打包一个tar
tar -cvzf etcbak.tar.gz etc/     //打包压缩一个 tartar -xvf etcbak.tar              //解开一个tar
tar -zxvf etcbak.tar.gz etc/     //解压一个tartar -tvf   XXX.tar   //列出xxx.tar文件中的内容tar -cvf my.bak.tar --exclude=/home/123 --exclude=/home/125 /home   //打包一个tar 同时排除一部分文件夹  

       打包

      压缩文件后,每次的HASH值(MD5)都不相同的原因_sun0322-CSDN博客_同一个文件md5每次不一样

      tar -tvf   XXX.tar   //列出xxx.tar文件中的内容

      结合其他命令使用 , tar -tvf | grep keyWord

       // Linux中,压缩,只能针对一个文件进行压缩。

       // 所以,我们一般先把多个文件打到一个tar文件中,

       // 然后再对这个tar文件进行压缩

・实际应用 :AP2  环境配置,和AP1 相同 (打包时,会保持文件的属性情报.)

AP1
tar -cvf /home/user001/bin.tar /Tool/Apl/binAP2
tar -xvf /home/user001/bin.tar  -C /Tool/Apl/bin --strip-components 3--strip-components Number 是指要去除的目录层数,这里是3,说明要从顶级目录开始去掉3层目录

・tar -zxvf xxx.gz、 出现 これはtarアーカイブではにようです。

         LANG=C tar -zxvf xxx.gz        (tar: This does not look like a tar archive.)

使用,【gunzip】命令

21.ls

・ls 不显示日期信息 (自动化比较时,生成实际值和期待值比较)

find /AAA/BBB/CCC/XXX | xargs ls -lpd | awk '{print $1,$3,$4,$5,$9}


ls -lpd /AAA/BBB/CCC/XXX/file001.xml | awk '{print $1,$3,$4,$5,$9}

ls -lpd /AAA/BBB/CCC/XXX/file001.xml | awk '{print $1,$3,$4,$5,$9} > 1.txt

〇  ls -lpd /AAA/BBB/CCC/XXX/file001.xml 2>&1| awk '{print $1,$3,$4,$5,$9} > 1.txt
×  ls -lpd /AAA/BBB/CCC/XXX/file001.xml | awk '{print $1,$3,$4,$5,$9} > 1.txt 2>&1 
       ×: 这种写法,错误输出,无法写入到文件 1.txt中
 

・其它

显示所有文件夹
ls -d */
ls -ld */

ls -l  //查看文件一览
ls --full-time // 显示年的信息
ls -l ./|grep "^d"|wc -l  // ^d 查看以d开头, 即文件夹的个数
ls -l ./|grep "^-"|wc -l  //^-   查看以 -开头, 即文件的个数
ls -a 
ls -lrt // 最新的文件在下面显示  (!! 文件比较多的时候,推荐使用这种方式) // -r reverse 相反的
ls -lh // -h, --human-readable // M
ls -lF // 文件后面追加标记目录后显示斜杠(/);可执行文件后显示星号(*);符号链接后显示符号@

・total 12 “所列出内容的磁盘占用空间总和值。单位为kbytes" // 应该都是4的倍数,Linux以块为单位存储,1个块是4KB

・RWX RWX RWX 后面的内容 表示 ,文件里面 文件夹的个数 

   通常要 再 减去 2 才是实际文件夹 的个数 因为包含 ./ ../

      7  。。。。。。。sxz001

   

ll -l ./|grep "^d"|wc -l  // ^d 查看以d开头, 即文件夹

ll -l ./|grep "^-"|wc -l  //^-   查看以 -开头, 即文件

===

ls --full-time // 显示年的信息

===

文件大小单位时byte

7位是1M左右 (1,000,000)

===

ls -a

当期待有文件,却找不到文件时,尝试使用 ls -la

 有时,文件的所有者是隐藏文件 「.」开头

以「.」开通的文件,即使使用 sudo su - 到对应的目录下后,也看不到指定的文件

ls -la
-l   长格式列出
-a   显示所有文件,包括隐藏文件和目录(所有以“.”为开始的文件和目录为隐藏文件)
所以ls -la 是列出当前目录中的所有文件和目录,包括隐藏文件和目录

===

在linux下,以点"."开头命名的文件在系统中被视为隐藏文件。
因此,如果想隐藏某个文件或目录,
一种简单的办法就是把文件名命名为点开头。 对于目录backcron,
可以这样操作隐藏:mv backcron .backcron
如何查看以“.”开头的文件,
可以用: ls -a -a 表示不忽略以点“.”开头的文件。

ls -F

-F 该选项
在每个目录后显示斜杠(/);
在每个可执行文件后显示星号(*);
在每个符号链接后显示符号@

---文件类型

在Linux下一切皆文件 everything is file,包括目录也是文件的一种而这些文件被分为七种类型:
• -:普通文件  
• d: 目录文件 
• b: 块设备 
• c: 字符设备 
• l: 符号链接文件  
• p: 管道文件pipe 
• s: 套接字文件sock

---Linux中ls命令的用法详解 - 白蓝的橙 - 博客园

--- 文件排序

// 最新的文件在上面显示
ls -lt// 最新的文件在下面显示  (!! 文件比较多的时候,推荐使用这种方式)
ls -lrt// -r reverse 相反的

---linux系统下查看文件大小命令(以G/M/K为单位查看)

ls -lh
// -h, --human-readable

======================

22.ps

查看进程中的线程

-T Show threads, possibly with SPID column.

ps -T -p <pid>

THREAD DISPLAY
       H      Show threads as if they were processes.

       -L     Show threads, possibly with LWP and NLWP columns.

       m      Show threads after processes.

       -m     Show threads after processes.

       -T     Show threads, possibly with SPID column.

--

查看服务

ps -e | grep ftp   查看服务

PS的aux和-ef参数

     PS的aux和-ef参数 - Linux操作系统:Ubuntu_Centos_Debian - 红黑联盟

    

    关于ps -aux | grep KeyWork1 | grep XXX.jar | grep -v grep | wc -l

      ・可以在检索结果中,再次查询

      ・grep -v grep :去除grep 命令本身

      ・wc -l:统计查询出来的件数 (是件数(条数,行数),不是个数(一行可能有多个XXX.jar))

    

 ps aux :

      最常用的 BSD 风格选项组合,其中的 a表示所有关联到终端的进程,

      如果同时使用 x 则代表所有进程;u 表示列出进程的用户。

    ps -elf : // 常用  ps -elf | grep XXX

    ps -ef // 常用

          unix标准风格组合,其中-e 代表列出所有进程,-l 代表长格式,-f 代表完整的格式

查看连接用户

除了who之外,还可以使用如下命令

ps -aux | grep sshd

---

Linux学习笔记:ps -ef、ps aux、kill -9 - Hider1214 - 博客园

.ps -aux  // BSD风格

1.USER:用户名称
2.PID:进程号    // kill -9 PID
3.%CPU:进程占用CPU的百分比
4.%MEM:进程占用物理内存的百分比
5.VSZ:进程占用的虚拟内存大小(单位:KB)
6.RSS:进程占用的物理内存大小(单位:KB)
7.TTY:终端名称(缩写),若为?,则代表此进程与终端无关,由系统启动的 
8.STAT:进程状态,其中S-睡眠,s-表示该进程是会话的先导进程,N-表示进程拥有比普通优先级更低的优先级,R-正在运行,D-短期等待,Z-僵死进程,T-被跟踪或者被停止等等
9.START:进程的启动时间
10.TIME:CPU时间,即进程使用CPU的总时间
11.COMMAND:启动进程所用的命令和参数,如果过长会被截断显示 
 ps aux | grep mysql | grep -v grep | awk ‘{print "kill -9" ,$2}’ | sh

.ps -ef   // System V展示风格

1.UID:用户ID
2.PID:进程ID
3.PPID:父进程ID
4.C:CPU用于计算执行优先级的因子。数值越大,表明进程是CPU密集型运算,执行优先级会降低;数值越小,表明进程是I/O密集型运算,执行优先级会提高 
5.STIME:进程启动的时间
6.TTY:完整的终端名称
7.TIME:CPU时间
8.CMD:完整的启动进程所用的命令和参数 

===

ps aux 和ps -elf 区别

・ aux (①BSO 风格、②主要关注的是进程的资源占用情况
  a 所有关联到终端的进程
  x 所有进程
  u 列出进程的用户

================

・-elf (①UNIX 风格、②则更多的关注进程的状态和从属关系
 e 列出戳有进程
 l 长格式
 f 完整格式

===aux

USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.0  0.4 185956  5996 ?        Ss   Feb22   3:23 /sbin/init splash

USER:运行该进程的用户名称。
PID:进程的ID。
%CPU:该进程使用的CPU时间百分比。
%MEM:该进程使用的物理内存百分比。
VSZ:该进程使用的虚拟内存大小,单位为KB。
RSS:该进程使用的非交换出去的物理内存大小,单位为KB。
TTY:该进程所在的终端。
STAT:该进程的状态。
START:该进程开始的时间。
TIME:CPU实际使用的时间。
COMMAND:产生此进程的命令。

===-elf

F S UID        PID  PPID  C PRI  NI ADDR SZ WCHAN  STIME TTY          TIME CMD
4 S root         1     0  0  80   0 - 46716 -      Feb22 ?        00:03:23 /sbin/init splash

F:进程标志,表示进程的状态。
S:进程的状态。
UID:运行该进程的用户ID。
PID:进程的ID。
PPID:父进程的ID。
C:进程使用的CPU资源的百分比。
PRI:进程的优先级。
NI:进程的nice值。
ADDR:进程的内存地址。
SZ:进程的大小。
WCHAN:如果进程处于睡眠状态,该列将显示睡眠中的系统函数名。
STIME:进程开始的时间。
TTY:该进程所在的终端。
TIME:CPU实际使用的时间。
CMD:产生此进程的命令。

================

ps -ef 和 ps -elf 在显示时的区别,举个例子

ps -efps -elf都是用于显示进程信息的命令,但在显示时有一些区别。

  1. ps -ef:以默认格式显示进程信息。它会列出所有进程,并显示以下列:

    • UID:进程的所有者ID。
    • PID:进程ID。
    • PPID:父进程ID。
    • C:CPU使用的时间片百分比。
    • STIME:进程启动时间。
    • TTY:进程所关联的终端。
    • TIME:进程的累计CPU使用时间。
    • CMD:进程的命令行参数。

    示例:

    UID        PID  PPID  C STIME TTY          TIME CMD
    root         1     0  0 06:36 ?        00:00:07 /sbin/init
    root         2     0  0 06:36 ?        00:00:00 [kthreadd]
    root         3     2  0 06:36 ?        00:00:00 [ksoftirqd/0]
    
  2. ps -elf:以长格式显示进程信息。它会列出所有进程,并显示以下列:

    • F:标志符,表示进程的标志位。其中,<表示高优先级,N表示低优先级。
    • S:进程状态,如S表示睡眠状态,R表示正在运行,Z表示僵尸进程等。
    • UID:进程的用户ID。
    • PID:进程ID。
    • PPID:父进程ID。
    • PRI:进程优先级。
    • NI:nice值,表示进程的优先级调整。
    • VSZ:虚拟内存大小。
    • RSS:物理内存大小。
    • WCHAN:进程等待状态。
    • ADDR:该进程在内存中的位置。
    • SCHED:进程的调度策略。
    • TTY:进程所关联的终端。
    • TIME:进程的累计CPU使用时间。
    • CMD:进程的命令行参数。

    示例:

    F S   UID    PID   PPID  PRI  NI    VSZ   RSS WCHAN  STAT TTY        TIME COMMAND
    4 S     0      1      0  20   0  268824  9676 poll_s Ss   ?          0:01 /sbin/init
    1 S     0      2      0  20   0       0     0 kvm-th S    ?          0:00 [kthreadd]
    1 S     0      3      2  20   0       0     0 smpboo S    ?          0:00 [ksoftirqd/0]
    

总体而言,ps -elf的输出更详细和易读,可以提供更多的进程信息。但是在某些情况下,ps -ef的简洁输出更方便查看。

示例:

=====================

==============================

23.chsec

           AIX中,使用此命令,修改配置文件键值对

sudo su -chsec -f /etc/security/lastlog -s userName -a unsuccessful_login_count=0passwd userNameinput the new Password

・↑AIX重置密码

・↓Linux重置密码

pam_tally2 -u userName --reset
passwd userName

24.sed

      24.1处理替换字符等操作

     Linux中的sed命令,使用方法之一「替换字符串中的内容 」,以及「s/ / / 」和「s/ / /g」之间的区别_sun0322-CSDN博客

      24.2 查看文件中,指定的行数  查看文件的50行到60行

       sed -n "50,60p" theFileName

      24.3 在某一行后面,加入一行新的内容

sed -i '60a column1,column2,column3' xxxx.csv// 在60行之后,插入一行新的内容
// 新的内容在第61行
// 「column1,column2,column3」是新插入的内容

      24.4 删除文件的指定行


sed -i '20,30d' filename    删除第20-30行

      24.5 sed的更多操作

shell自动化处理_相关知识整理(整理中)20210329_sun0322-CSDN博客

25.locate

    locate   XXXX.classs   查找文件(只限Linux中使用)

26.cal

    cal -y 显示日历

cal 9 1752

※ 2100年不是闰年

27.mkdir

     创建文件夹

      mkdir -p :递归创建目录,即使上级目录不存在,会按目录层级自动创建目录

mkdir -p /xxx1/xxxx2/xxxx3

      mkdir -m :创建文件夹时,指定访问权限

mkdir -m 777 mydir

      mkdir m755 TEST_FOLDER  // OK 没有问题(m755 可以没有空格)

mkdir m755 TEST_FOLDER

28.touch

     创建文件

29.rm

    rem -r  directory  // 删除文件夹时,要带上参数r

    Linux cannot remove 'XXX': Is a directory 解决办法_sun0322-CSDN博客

     参数 v 显示删除时的详细信息

   

    删除某个文件之外,其他所有的文件

   rm !(test1)     // 删除除test1之外,所有的文件  rm !(test1|test3) // 删除除test1、test3之外,所有的文件 (文件之间,使用或者符号连接)// ※1 注意!!! 文件和 运算符之间 不能带有空格// ※2 当文件不存在时,会出如下的信息Couldn’t delete file: No such file or direcotryrm : `!(test1|test3)' を削除できません:そのようなファイルやディレクトリはありません。

30.vi

vi的使用

Linux中 Vi的使用_sun0322-CSDN博客

31.特殊符号之【`】 不是单引号 (是反单引号)

可以直接输出命令执行后的结果

这个符号时【反单引号】,``里面是可以执行的语句

sxz001@sxzap01:~$ uname -n
sxzap01
sxz001@sxzap01:~$ echo aaa_`uname -n`_bbb
aaa_sxzap01_bbb
sxz001@sxzap01:~$

获得日期  ( ※:date 后面有空格)

xxx.log`date +%Y%m%d`ls -l xxx.log`date +%Y%m%d`echo xxx.log`date +%Y%m%d`

32.特殊符号之【&】 

在Shell中,“$“和“&“的作用_sun0322-CSDN博客

放在命令最后,可以让程序后台运行。

后面跟上一个命令,可以执行该命令

错误输出,也输出到标准输出中

33.sudo

     sudo su -

34.su

     su targetUserName

su - 与su
通过su切换用户还可以直接使用命令su USERNAME,与su - USERNAME的不同之处如下:
su - USERNAME切换用户后,同时切换到新用户的工作环境中// 使用 id 命令,查看,是变更后 的用户的id情报
su USERNAME切换用户后,不改变原用户的工作目录,及其他环境变量目录// 使用 id 命令,查看,是变更前 的用户的id情报

非 root 用户 执行 此命令 时, 需要输入 密码

35.log设定(Tera Term)

    Teraterm的Log设定_sun0322-CSDN博客_tera term怎么保存log

36.ll (只限Linux中使用)

37.id

  id // 显示下面的所有信息

   id -u   显示uid ; id -nu 显示用户信息

   id -g   显示gid ; id -ng 显示组信息

   id -G    显示所有的组信息;   id -nG 显示附加值信息

  上面的绿字,只是ID,加上 n 后,可以显示名字

应用:

    ・Jenkins脚本执行时,想查看执行脚本的用户,我们可以使用此命令查看

 ・docker -u 参数,指定 用户与组时,使用此命令,获取用户与组信息

38.特殊符号之 【$()】

    ・echo $(id -u)  等同于  echo `id -u`

    ・使用【$()】连续执行命令

                echo $(pwd; pwd)

                echo $(cd ..; pwd)

  ・计算变量相加

 Linux Shell 数字相加

×:

COUNT=0
COUNT=$COUNT+1
echo ${count}
---
0+1

〇:

COUNT=0
COUNT=$(( $COUNT+1 ))
echo ${count}
---
1

39.dirname

           dirname /ssss/aaaa/bbbb/test.txt

            返回结果

           dirname /ssss/aaaa/bbbb

  获取当前正在执行的shell所在的位置


workdir=$(cd $(dirname $0); pwd)步骤1
dirname $0,取得当前执行的脚本文件的目录
步骤2
cd 到   sh 所在的工作目录
步骤3 
pwd显示当前工作目录

关于 $0,代表sh自身

与该sh被调用时,调用的方法有关。

sxz001@sxzap01:~$ ls
myJava  mySoftware  temp  test.sh
sxz001@sxzap01:~$ cat test.sh
echo "hello word"
echo $0sxz001@sxzap01:~$ sh /home/sxz001/test.sh
hello word
/home/sxz001/test.sh
sxz001@sxzap01:~$ sh ./test.sh
hello word
./test.sh
sxz001@sxzap01:~$ sh test.sh
hello word
test.sh
sxz001@sxzap01:~$

40.find

  1.在当面目录下查找 指定名字的文件 (包含子目录)

  find ./ -name "*.csv"
// 2. 查看文件一览(可以看到子文件夹里面的内容)
find /AAA/BBB -type f | sort | xargs sum >result.txt 2>&1
find /AAA/BBB -type f | sort | xargs ls -lpd >result.txt 2>&1

↓ 2>&1(windows Linux 都适用)

bat shell 命令行中 2>&1 的含义_sun0322-CSDN博客

2.只在当面目录下检索,不查询子目录  // -maxdepth 1

  find /AAA/BBB/CCC -maxdepth 1 -name "*.csv"===find /AAA/BBB/CCC -maxdepth 1 -type f | sort | grep -e "yourFileName" | grep -v grep | xargs md5sumfind /AAA/BBB/CCC -maxdepth 1 -type f | sort | grep -e "yourFileName" | grep -v grep | xargs ls -l
===■経緯
子文件夹里面的文件,没有访问权限,使用时,出现“没有访问权限的警告”
不查询没有访问权限的文件夹,即可解决此问题■扩展:查询多个文件(以.xml结尾)find /AAA/BBB/CCC -maxdepth 1 -type f | sort | grep -e "yourFileName1" -e "yourFileName2.xml$" | grep -v grep | xargs md5sum

3. find -name XXX

// -maxdepth 1 要写在最前面
find /AAA/BBB/CCC -maxdepth 1 -type f -name yourFileName | xargs ls -l

4.查找文件夹下,哪些文件,含有某字符

find. -name "*.c" | xargs grep -Hn sum | sort > result.txt

漫画 | Unix/Linux 比 Windows 差远了!_码农翻身-CSDN博客

5.查找文件,忽略大小写,显示全路径,按修改时间的顺序显示

find /AAA/BBB/CCC -iname "*.csv" |xargs ls -lt

6.find 参数 mtime

n表示文件更改时间距离为n天, -n表示文件更改时间距离在n天以内,+n表示文件更改时间距离在n天以前。
例如:
-mtime 0 表示文件修改时间距离当前为0天的文件,即距离当前时间不到1天(24小时)以内的文件。
-mtime 1 表示文件修改时间距离当前为1天的文件,即距离当前时间1天(24小时-48小时)的文件。
-mtime+1 表示文件修改时间为大于1天的文件,即距离当前时间2天(48小时)之外的文件
-mtime -1 表示文件修改时间为小于1天的文件,即距离当前时间1天(24小时)之内的文件

---

查找文件更新日时在距现在时刻5天以内的文件
find ./ -mtime -5找“5天前的那一天被更改过的档案名”find / -mtime 5查找文件更新日时在距现在时刻5天以上(以前,之前)的文件
find ./ -mtime +5查找文件更新日时在距现在时刻24小时之前的文件
find ./ -mtime +0

---

 ---

41.history

查看执行过的命令

42.1.md5sum fileName

 查看文件的信息摘要

===========

powerShell

查看文件信息摘要_sun0322-CSDN博客

 Get-FileHash .\yourFileName -Algorithm SHA256 | Format-List

===========

42.2.sum fileName

   查看

     ・文件校验码

   ・文件所占的快递大小。  

43.systemctl

  启动停止服务

       systemctl start XXXd.service

       systemctl stop XXXd.service

    ・启动关闭防火墙:     MySQL配置允许远程连接_asdXT的博客-CSDN博客_mysql允许远程连接

    ・启动sfpt服务:systemctl start vsftpd

===

・查看防火墙状态信息
systemctl status firewalld・打开防火墙(如果不是显示active状态,需要打开)
systemctl start firewalld・查看防火墙所有信息
firewall-cmd --list-all・查看防火墙开放的端口信息(默认为空)。。。明明有开放端口,但是看不到啊。。。也许外层还有防护墙
firewall-cmd --list-ports・查看所有永久开放的端口(默认为空)
firewall-cmd --list-ports --permanent

===

# 针对一个ip段访问 
firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.1.0/24" port protocol="tcp" port="22" accept"

192.168.1.0是你的IPV4地址;/24是你的子网掩码,代表255.255.255.0。

===

# 开启防火墙 
systemctl start firewalld.service # 防火墙开机启动 
systemctl enable firewalld.service# 关闭防火墙 
systemctl stop firewalld.service # 查看防火墙状态 
firewall-cmd --state #查看防火墙规则(只显示/etc/firewalld/zones/public.xml中防火墙策略)
firewall-cmd --list-all-zones# 查看现有的规则 
firewall-cmd --zone=public --list-ports # 重载防火墙配置 
firewall-cmd --reload # 添加单个单端口 
firewall-cmd --permanent --zone=public --add-port=81/tcp # 添加多个端口 
firewall-cmd --permanent --zone=public --add-port=8080-8083/tcp # 删除某个端口 
firewall-cmd --permanent --zone=public --remove-port=81/tcp # 针对某个 IP开放端口 
firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.1.51" port protocol="tcp" port="8082" accept" # 删除某个IP
firewall-cmd --permanent --remove-rich-rule="rule family="ipv4" source address="192.168.1.51" accept"# 针对一个ip段访问 
firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.1.0/24" port protocol="tcp" port="22" accept"#查看可开启的服务
firewall-cmd --zone=public --list-services# 开放服务
firewall-cmd --add-service=ssh --zone=public --permanent# 删除服务
firewall-cmd --remove-service=ssh --zone=public --permanent# 添加操作后别忘了执行重载 
firewall-cmd --reload

===

  

44.wc

wc fileName输出文件中的行数、单词数、字节数

 wc -l fileName

 统计文件的行数 (统计换行符的个数, l 是 line 的缩写)

 ※ 注意,有的时候文件最后一行没有换行符,这时候,统计出来的行数,比实际行数少1行

45.hexdump

 hexdump fileName以十六进制形式查看文件 (windows的换行  显示位0a0d,实际应该是0d0a,这里面涉及了低位,与高位的问题,所以十六进制的显示,与实际的表示,是反过来的)■十六进制
,:2C
0:30
A:41
a:61

■apache (hpptd)(httpd.server)
早期的apache小组,现在已经成为一个拥有巨大力量的apache基金会。 他们把起家的apache更名为httpd,
也更符合其http server的特性。而apache现在成为 apache基金会下几十种开源项目的标识。apache和httpd是一个,到apache2后就叫httpd了

46.xargs

46.1

  find /XXX/XXX/XXX -type f | xargs sum   // 得到的两个参数时 校验码  与 文件的块大小

  find /XXX/XXX/XXX -type f | xargs md5sum  // 后面可以是各种命令  比如 rm 那就是删除所有找到的文件

  find /XXX/XXX/XXX -type f | xargs ls -l  // 这种方式,可以显示文件的

Linux xargs命令-(转载) - 骑单车去旅行 - 博客园

----

46.2

加-i 参数直接用 {}就能代替管道之前的标准输出的内容

(例:复制文件)

find /AAA/BBB/CCC/ -maxdepth 1 -type f | xargs -i cp {} /Work/Back
find /AAA/BBB/CCC/ -maxdepth 1 -type f | xargs -i sudo cp {} /Work/Back
find /AAA/BBB/CCC/ -maxdepth 1 -type f | grep -e ".yml$" | xargs -i sudo cp {} /Work/Back

47.vmstat

Linux vmstat命令实战详解_浮生一梦-CSDN博客_vmstat

vmstat命令是最常见的Linux/Unix监控工具,属于sysstat包。
可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,
内存使用,虚拟内存交换情况,IO读写情况。
这个命令是我查看Linux/Unix最喜爱的命令,一个是Linux/Unix都支持,二是相比top,我可以看到整个机器的CPU,内存,IO的使用情况,
而不是单单看到各个进程的CPU使用率和内存使用率(使用场景不一样)。


47.umask

umask:umask用来去掉目录或文件的某些权限

umask使用详解_modi000的博客-CSDN博客

=====================

      umask -S // 查看权限umask -p // 查看掩码 ※// 4位 后三位有效 第一位是 粘着位(sticky)

   粘着位(sticky)   ⇒ linux中的粘滞位(Sticky bit)_喵喵的博客-CSDN博客

linux系统规定文件的默认最大权限是666,目录的默认最大权限是777,那么umask=022 
需要反过来看就是755(u=rwx,g=rx,o=rx),
所以对应权限:1.目录:022->755(u=rwx,g=rx,o=rx) 
2.文件:022->644(u=rw,g=rx,o=rx) 

linux系统规定文件的默认最大权限是666

创建文件和目录时的默认权限umask_u013500740的博客-CSDN博客

umask 022 新建文件是 644

(666-022=644)

48.mv 

   1.除了移动文件之外,还可以用于给文件改名

                 mv aaa001 aaa002 // aaa001 ⇒aa002

            2.强制替换文件

                mv -f

49.jq

jq是Linux下面把文本字符串格式化成json格式的工具

Linux之jq - 北漂-boy - 博客园

jq '.key'

获取Json字符串中的key值

JSON 语法

jq使用,非常好的例子

linux 命令之jq_Gino的专栏-CSDN博客

50.SUID   SGID

Set User ID 的缩写

rwx rwx rw-

rws rwx rw-    // chmod u+s   //当运行某程序时,相应进程的属主,是程序文件自身的属主,而不是启动者;

rwx rws rw-    // chmod g+s

Linux 文件目录特殊权限设定(SUID,SGID,SBIT)_乐沙弥的世界-CSDN博客_linux特殊权限

Linux浅谈SUID,SGID,Sticky粘滞位对目录以及文件的相关作用_禾苗成长的技术博客_51CTO博客

■suid
====一般都作用于二进制文件上,一般不作用在目录上。
====■sgid: (rws)
====a.作用在目录上,当目录下新建文件时,以及文件夹时,那么自动获取目录的所属组作为文件或者文件夹的所属组。b.它也可以对二进制文件生效,但是很少使用。
====

     rws

51.usermod

・添加组

usermod -G groupname1,  groupname2 username

・确认

cat /etc/group | grep -e groupname1 -e groupname2

Linux添加/删除用户和用户组1、建用户:
adduser phpq                            //新建phpq用户
passwd phpq                            //给phpq用户设置密码
2、建工作组
groupadd test                          //新建test工作组
3、新建用户同时增加工作组
useradd -g test phpq               //新建phpq用户并增加到test工作组
注::-g 所属组 -d 家目录 -s 所用的SHELL
4.1、给已有的用户增加工作组
usermod -G groupname username
或者:gpasswd -a user group
4.2、给已有的用户增加多个工作组
usermod -G 附属组1,附属组2,...,附属组X  用户名
5、临时关闭:在/etc/shadow文件中属于该用户的行的第二个字段(密码)前面加上*就可以了。想恢复该用户,去掉*即可。
或者使用如下命令关闭用户账号:
passwd peter –l
重新释放:
passwd peter –u
6、永久性删除用户账号
userdel peter
groupdel peter
usermod –G peter peter   (强制删除该用户的主目录和主目录下的所有文件和子目录)
7、从组中删除用户
编辑/etc/group 找到GROUP1那一行,删除 A 或者用命令 gpasswd -d A GROUP
8、显示用户信息
id user
cat /etc/passwd

52.访问权限说明

■パターン1
AAA drwx r-x ---└BBB   drwx rwx ---└bbb.txt组用户,可以修改bbb.txt的内容组用户,无法再AAA目录下面创建文件 或者 文件夹组用户,可以修改AAA目录中,组用户 是 w 权限的文件组用户,可以再BBB目录中,创建文件 或是 文件夹■パターン2
AAA drwx rwx ---└BBB   drwx rwx ---└bbb.txt组用户,可以修改bbb.txt的内容■パターン3
AAA drwx r-x ---└BBB   drwx rwx ---└bbb.txt组用户,可以在BBB中创建文件夹============
即,BBB文件夹下面的权限,应该不受到AAA文件夹权限的影响!!!※1 但是,首先要有 对AAA文件夹的访问权限!!!
如果对AAA没有访问权限,是无法对bbb.txt进行操作的。※2AAA   701└BBB   701└DDD      701 // 可以访问,无权限在当前目录下执行 ls  // 705 就可以 执行 ls└ddd.txt   777 // 可以修改文件 // DDD 701、705 时,   无权限在目录下执行touch命令创建文件【5((r-x))】
============■XL Deploy
=====发布文件时,如果之前 DDD 文件夹下文件已经存在,step1.删除文件step2.创建文件  (使用连接的token对应的用户来创建文件)// 即创建之后,文件的各种权限信息都会改变
=====↑ 所以,对于 DDD文件夹,访问权限至少要设置为 703 // 或者改变上层文件夹的所属 ↑ ddd.txt 文件的权限至少是 706※ 建议 修改文件的所属!!!

只要对目录有(w)权限,那么即使没有对目录下文件的 r w 权限,也能删除该文件

比如: 左面 sxz001用户建立了一个ttt文件,

            右面tomcat用户  「rm -f ttt」可以删除该文件

53.gpasswd

  添加一个用户到一个组,同时保留以前添加的组时,使用 gpasswd 这个命令来添加操作用户

gpasswd -a user_name group_name

使用该命令,把用户从组中移除

gpasswd -d user_name group_name

54.adduser 创建用户

----

---

---

 查看sudo 权限的使用 cat sudoers

------

youuser ALL=(ALL) ALL
%youuser ALL=(ALL) ALL
youuser ALL=(ALL) NOPASSWD: ALL
%youuser ALL=(ALL) NOPASSWD: ALL第一行:允许用户youuser执行sudo命令(需要输入密码).
第二行:允许用户组youuser里面的用户执行sudo命令(需要输入密码). // 上面的 sudo 组
第三行:允许用户youuser执行sudo命令,并且在执行的时候不输入密码.
第四行:允许用户组youuser里面的用户执行sudo命令,并且在执行的时候不输入密码.■扩展
第三行: 指定的命令,可以使用sudo权限来执行
youuser ALL=(ALL) NOPASSWD: /usr/bin/chmod, /usr/bin/chown

----

---

对tomcat用户添加组后,

重新登陆,即可切换sudo 用户

55.grpup  .passwd   .sudoers

   查看所有组, 所有用户,sudo权限

--user
adduser phpq 
cat /etc/passwd | grep sxz--group
gpasswd -a user_name group_name
gpasswd -d user_name group_name
cat /etc/group | grep -e groupname1 -e groupname2--sudo
cat /etc/sudoers | grep %  // % 后面是组的名字

---

// 使用 vi 修改【/etc/sudoers】的内容 (让文件有写的权限)
yourUserName1 ALL = (ALL)NOPASSWORD: ALL
yourUserName2 ALL = (root)NOPASSWORD:/usr/bin/chmod, /AAA/BBB/CCC/aaa.sh// aaa.sh 可以时自己写的脚本,里面有各种命令,比如  su -使用时sudo /AAA/BBB/CCC/aaa.sh

56.kill

  kill -9 PID

■ windows
taskkill /pid 4740 /T   // 子程序也同时终了
taskkill /pid 4740 /p   // 制终了程序

57.awk

   Linux中awk工具的使用_谢公子的博客-CSDN博客_awk

以 : 为分隔,显示/etc/passwd中每行的第1和第7个字段awk -F ":" '{print $1,$7}' /etc/passwd  或  awk 'BEGIN{FS=":"}{print $1,$7}' /etc/passwd

// 使用 awk 获取 ps -aux 的返回值中的第二个项目,Kill 掉

 ps aux | grep mysql | grep -v grep | awk ‘{print "kill -9" ,$2}’ | sh

58.| 管道(|)    パイプ  管道 pite)

管道(|)命令用于将Command1命令的结果作为输入传给Command2命令■ 示例1
ls -l | grep XXX
// grep searchStr xxx.log  // 在log中查找字符串■ 示例2
ll -l ./|grep "^d" | wc -l  // ^d 查看以d开头, 即文件夹
ll -l ./|grep "^-" | wc -l  //^-   查看以 -开头, 即文件■ 示例3
cat -n index.html | more■ 示例4
find /XXX/XXX/XXX -type f | xargs md5sum  // 后面可以是各种命令  比如 rm 那就是删除所有找到的文件

59.echo

 echo abc >test001.txt

     //  文件有换行符  // 0a

60.其他用户修改文件后,对文件所属,组的影响

  不会有任何影响

 (可以改变文件的内容  使用 echo  或者 vi)

例:使用tomcat用户,修改 sxz001用户所属文件的内容。

61.tee

Linux tee命令 | 菜鸟教程

echo "XXX" | tee -a fileName

向文件中添加内容

62.查看系统・用户信息

#系统信息
hostname 或 uname -n     #主机名
history      #查看命令历史,有可能可以查看到管理员的一些重要命令,包括密码等
uname -a     #所有版本
uname -r     #内核版本信息uname -m     #Linux内核架构
cat /proc/version   #内核信息
cat /proc/cpuinfo   #CPU信息
cat /etc/*-release  #发布信息
cat /etc/issue      #发布信息#用户和组信息
whoami           #查看当前用户身份
who              #查看当前登录系统的所有用户
w                #显示已经登陆系统的用户列表,并显示用户正在执行的指令
users            #显示当前登录系统的所有用户的用户列表
id               #当前用户信息
id || (whoami && groups) 2>/dev/null     #当前用户信息
cat /etc/passwd | cut -d: -f1            #查看所有的用户名
cat /etc/passwd | grep "sh$"             #查看拥有bash的用户
awk '/\$1|\$6/{print $1}' /etc/shadow   #查看可以远程登录的用户
cat /etc/shadow  #查看密码
cat /etc/group   #查看组信息
last             #查看登录历史
more /etc/sudoers | grep -v "^#\|^$" | grep "ALL=(ALL)"    #查看拥有sudo权限的用户
sudo -l             #列出目前用户可执行与无法执行的指令 
awk -F: '$3==0{print $1}' /etc/passwd   #查看超级用户(uid=0),有些黑客将普通用户的uid改为0,则该普通用户也拥有了超级权限#登录信息
last             #查看最近登录成功的用户及信息,查看的是 /var/log/wtmp 文件
lastb            #查看最近登录失败的用户及信息,查看的是 /var/log/btmp 文件
lastlog          #显示系统中所有用户最近一次登录信息,读取的是 /var/log/lastlog 文件
cat /var/log/secure* | grep Accepted   #查看登录成功的记录
cat /var/log/secure* | grep Failed     #查看登录失败的记录
grep "Accepted " /var/log/secure* | awk '{print $1,$2,$3,$9,$11}'  #查看登录成功的日期、用户名及ip
grep "Failed password for root" /var/log/secure | awk '{print $11}'  #查看有哪些ip在爆破主机的root账号
grep "Failed password" /var/log/secure | awk {'print $9'} | sort | uniq -c | sort -nr  #查看爆破用户名字典#网络信息
ifconfig
arp -a
cat /etc/network/interfaces   #查看网络接口信息
route       #查看路由信息
traceroute baidu.com    #查看路由节点
cat /etc/hosts   #查看hosts文件
cat /etc/resolv.conf  #查看dns信息
cat /etc/services     #查看端口服务映射#服务、端口和进程信息
ps aux  /  ps -ef            #静态查看进程
pstree                       #查看进程树
top                          #动态查看进程
ps aux --sort -pcpu          #静态查看进程,根据cpu使用情况排行,从高到低
ps aux --sort -pmem          #静态查看进程,根据内存使用情况排行,从高到低
netstat -pantu               #查看端口信息
netstat -pantu | grep 18176  #查看端口连接情况,过滤含有18176端口的行,就可以查看连接的端口
cat /etc/inetd.conf          #由inetd管理的服务列表
cat /etc/xinetd.conf         #由xinetd管理的服务列表
cat /etc/exports             #nfs服务器的配置
cat /etc/services            #查看端口服务映射
ls -l /proc/18176/exe        #查看PID为18176的进程的可执行程序
lsof -p 18176                #查看PID为18176的进程打开的文件
lsof -c sshd                 #查看进程sshd打开的文件
lsof -i:33946                #查看33946端口对应的一些进程
ps -p PID -o lstart          #查看进程的启动时间点
fuser -n tcp 33946           #查看33946端口对应的进程PID#环境信息
env   #打印系统环境信息
set   #打印系统环境信息
echo  $PATH   #环境变量中的路径信息 
history       #历史命令
cat /etc/profile   #显示默认系统遍历
cat /etc/shells   #显示可用的shell

63.chage -l yourUserName

     // 查看密码过期时间

    http://www.voidcn.com/article/p-xmrfzbzi-bee.html

64.ssh

      ssh userName@serverName

      输入之后,会让你输入密码

  无法连接时,

          ssh: connect to host  serverName port 22: Connetion timed out

可以在cmd命令行下直接执行【ssh userName@serverName】

数码密码后(密码可以鼠标右键粘贴)

登录后的效果和TeraTerm登录效果相同

ssh -i 使用认证文件,不需要再输入密码

ssh -i identity_file userName@serverName

identity  [aɪˈdɛntɪtɪ]  // n.  身份;同一性;一致;特性;个性;恒等式  // ssh -i  // scp -i

====

ssh 连接时 忽略 known_hosts check

这个文件(known_hosts)里面的值如果是旧的,会造成无法连接!!!!!

known_hosts 文件中的 ssh-rsa 值是根据远程主机的公钥生成的。当您第一次连接到一个远程主机时,您的SSH客户端会将该主机的公钥保存在known_hosts文件中。每次连接到该主机时,SSH客户端都会验证该主机的公钥是否与known_hosts文件中的相同,以确保您正在连接到正确的主机。如果公钥【密钥指纹信息】不匹配,SSH客户端会发出警告并停止连接。这有助于保护您的计算机免受中间人攻击。

忽略check的方法

ssh -o "StrictHostKeyChecking=no" username@hostname

===

65.function

#! /bin/bashfunction yourFunction {yourFunction1yourFunction2
}function yourFunction1 {command1command2
}function yourFunction2 {command3command4
}# 要写在函数定义的下面(如果写在函数上面,会提示找不到命令)
# 注释最好使用英语,避免文字编码问题
yourFunction

66.unzip

     和tar一样,都可以解压缩

     linux下 tar,zip,unzip命令详解_wudinaniya的博客-CSDN博客_linux安装unzip命令和tar命令

     不过需要安装

     unzip xxxx.zip

    安装方法

扩展,使用gzip   命令进行压缩

yum -y install unzip zip

67.zip

     和tar一样,都可以压缩

把 【/Work/1117/】目录下的【aaa】文件夹 打成一个压缩包

cd /Work/1117
zip -r aaa.zip aaa
chmod 666 aaa.zip

打包时,带上主机名

zip -r `uname -n`_aaa.zip aaa

zip更多操作

在不解压的情况下查看一个zip文件的内容,使用下面的命令:zip -sf test.zip删除zip中的文件
zip -d test.zip smart.txt像 zip 中 添加 文件
zip test.zip smart.txt

68.diff

      diff /XXX/XXX/file1 /XXX/XXX/file2

69.scp 获取远程文件

scp -r root@otherServerName:/usr/local/aa /usr/local/
scp root@otherServerName:/usr/local/aa/file1.txt /usr/local/
// -r是复制目录
// 注意,不要忘了冒号
// 连接的时候,会显示RSA KEY 公钥 私钥 证明书之类的信息
// 确认连接yes之后,输入密码// IP地址也可以
scp -r root@XXX.XXX.XXX.XXX:/usr/local/aa /usr/local/

70.screenfetch 显示系统信息

71.sl 小火车

小火车

72.cmatrix:黑客帝国

---

73.特殊符号【./】

前言:

    目录下有 tool.sh,我们进入当前目录后,直接输入tool.sh后,回车,没有任何效果。

    只有 ./tool.sh时,tool.sh才会被执行

“.”表示当前目录,“./”表示执行当前目录下可执行文件。

74.netstat

netstat -tunlp | grep 3306netstat -an | grep 3306netstat -anp | grep  -e 3306 -e PID
-t (tcp) 仅显示tcp相关选项
-u (udp)仅显示udp相关选项
-n 拒绝显示别名,能显示数字的全部转化为数字
-l 仅列出在Listen(监听)的服务状态
-p 显示建立相关链接的程序名

有些内容,需要管理员权限才能看到

---

(Not all processes could be identified, non-owned process infowill not be shown, you would have to be root to see it all.)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp6       0      0 :::3306                 :::*                    LISTEN      -

---

---

root@sxzap01:~# netstat -an | grep 3306
tcp6       0      0 :::3306                 :::*                    LISTEN
tcp6       0      0 192.168.131.128:3306    192.168.131.1:50010     ESTABLISHED

---

============

74.1.netstat、rmsock  (AIX)

AIX 服务中  netstat -anop 参数不好用 (具体是参数p不好用)

netstat -Aan | grep 1334

f10002000043c398 tcp4 0 0 *.1334 *.* LISTEN

rmsock f10002000043c398 tcpcb

removes a socket that does not have a file descriptor.

删除没有文件描述符的套接字。

The socket 0x43c008 is being held by proccess 217248 (writesrv).

rmsock 命令
用途
除去不包含文件描述符的套接字。

语法
rmsock Address TypeofAddress

描述
rmsock 命令除去不包含文件描述符的套接字。它接受 socket、tcpcb、inpcb、ripcb 或 rawcb 地址并将其转换成套接字地址。 然后检查每个进程所有打开的文件以查找套接字的匹配。如果没找到匹配,对该套接字执行异常终止操作,而不考虑套接字 linger 选项的存在。套接字保留的端口号释放。如果发现匹配,文件描述符和主进程状态显示给用户。结果发送到 syslogd 并在 /var/adm/rmsock.log 文件中记录。


netstat -Aan |grep 9900    #会出现一大串列表.
rmsock f10000f303268358 tcpcb    #参数为上面列表中,每行前面的序号.该命令会显示一个PID.
ps -ef |grep 807084    #上面输出的PID.

ps -ef | grep 217248

root 217248 159882 0 Jan 08 - 0:00 /usr/sbin/writesrv

===========

75.cron

crontab -l

cat /etc/crontab

Linux中的Cron ,任务计划_sun0322-CSDN博客

76./dev/null

/dev/null 是一个特殊的设备文件,所有接收到的数据都会被丢弃。有人把 /dev/null 比喻为 “黑洞”,比较形象恰当。

关于 /dev/null 差点直播吃鞋的一个小问题

---

我们的定时任务、异步 MQ 的 jar 包程序等都会使用 System.in.read() 等阻塞程序,防止程序退出

但是,

使用 tail -f /dev/null 会永久阻塞

---

启动一个jar,后台运行,

然后,使用这个命令,传入jar的pid,可以停止这个jar

(扩展:可以利用tail -f /dev/null让容器一直处于runing状态

    利用tail -f /dev/null命令防止container启动后退出(示例代码)_136.la)

 ----

tail --pid=$pid -f /dev/null

   // ↑ 这种写法可以终止(jar)进程、↓ 使用man命令,查看得到的结果

   with -f, terminate after process ID, PID dies

     (同 -f 一起使用,当 PID 所对应的进程死去后终止)

---

77.nohup

nohup ./xxx.sh &

Linux 下后台运行脚本(防止退出Xshell后程序中断)_林胖胖哒的博客-CSDN博客

78.lsof

lsof -i:port

Linux命令 lsof -i:端口号 ——有什么用途_sun0322-CSDN博客

79.ln

创建硬链接,软连接(符合链接 Symbolic Link)

 

80.unlink  解除软连接

81.which

查看执行文件的位置
  (搜索某个系统命令的位置,并且返回第一个搜索结果。
   也就是说,使用which命令,就可以看到某个系统命令是否存在,以及执行的到底是哪一个位置的命令。 )

which sss
/bin/sss

82.特殊符号【"】(双引号)  与【'】单引号

・双引号中的变量${XXX},可以输出对应的值

・单引号中的变量${XXX}, 直接按照【${XXX}】原来的样子执行。

下面是例子

#!/bin/bash
DAYS=2
DATE1=`date +%Y%m%d --date='${DAYS} days ago'`
DATE2=`date +%Y%m%d --date="${DAYS} days ago"`

83.符号【&&】、【||】

&&:用来执行条件成立后执行的命令
||:用来执行条件不成立后的执行命令

。。。
RETCODE=$?
[ $RETCODE -ne 0 ] && return $RETCODE

linux之shell命令——条件判断(&& || test)_shang_feng_wei的博客-CSDN博客

84.basename

basename /tmp/test/file.txt

file.txt

basename /tmp/test/file.txt .txt 

file    // 指定后缀时,可以去掉后缀(上面例子中,指定了后缀 .txt)

85.gunzip

可以解压缩 gz 结尾的文件

86.locale // 命令

sxz001@sxzap01:~$ locale -a
C
C.UTF-8
en_US.utf8
POSIX

(C对应ASCII编码)

87.LANG // 系统变量  // Language的缩写

sxz001@sxzap01:~$ echo $LANG
en_US.UTF-8
sxz001@sxzap01:~$

指定执行命令时,指定系统显示所用的语言

LANG=C tar -zxvf xxx.gz

88.安装语言包・查看默认语言设置

sudo apt-get install  language-pack-zh-hans
cat /etc/default/locale

---

 安装之后

89.showmount

#查询本机nfs共享目录情况

showmount -e localhost

显示效果如下

     /AAA/BBB/CCC  192.168.1.122/24,192.168.1.123/24

含义:
   (对 192.168.1.122,192.168.1.123者两个IP地址共享此目录)
     前提,需要启动服务
          service rpcbind start
          service nfs start

NFS挂载

英文Network File System(NFS),是由SUN公司研制的UNIX表示层协议(presentation layer protocol),能使使用者访问网络上别处的文件就像在使用自己的计算机一样。

Linux NFS挂载 - 整合侠 - 博客园 (cnblogs.com)

90.Linux的shell命令,直接在终端执行。

・写成一行,需要分号(分号相当于换行)

if [ -d /AAA/BBB/ccc ]; then echo "111"; fi

・改行时(不需要分号) ,以下命令,也可以直接在终端执行

if [ -d /AAA/BBB/ccc ]; then echo "111"
fi


・其他 for  // for后面,有两层括号式正确的

for ((c=1;c<=5;c++)); do ls -l /AAA/BBB/CCC/xxx*.log; sleep 3; done

・其他 while  

while true; do TIME=`date "+%H:%M:%S"`;FILENAME=`ls -l | grep txt`;echo "${TIME},${FILENAME}";sleep 1; done

91.特殊符号【{}】 大括号

1.用法1
对大括号中的以逗号分割的文件列表进行拓展。
 如

 touch {a,b}.txt 

 结果为
  a.txt b.txt。

对大括号中以点点(…)分割的顺序文件列表起拓展作用,
如:  

touch {a…d}.txt

 结果为
  a.txt b.txt c.txt d.txt。

2.用法2
变量 ${AAA_BBB}

3.用法3 

   xargs -i cp {} /AAA/AAA

  传递前面管道得到的参数

find /AAA/BBB/CCC/ -maxdepth 1 -type f | xargs -i cp {} /Work/Back

92.gzip

gzip通常用于文件压缩,但是不能压缩文件夹,并且压缩完原文件不保留

[root@localhost home]# ls
abc.txt  admin  client  ClientM.c
//压缩ClientM.c文件
[root@localhost home]# gzip ClientM.c
//压缩为ClientM.c.gz
[root@localhost home]# ll
-rw-r--r-- 1 root  root     12 Aug 30 22:42 abc.txt
drwx------ 3 admin admin    92 May 14 02:27 admin
-rwxr-xr-x 1 root  root  17472 Aug 30 18:14 client
-rw-r--r-- 1 root  root   8668 Aug 30 10:10 ClientM.c.gz
[root@localhost home]#

使用gzip命令压缩, gunzip命令解压缩

同样,解压的时候,压缩文件不保留

生成的文件,后缀【.gz】

扩展【.tgz】

tar -zcvf examples.tgz examples

93.mount

在linux当中所有的存储设备如u盘、光盘、硬盘等,都必须挂载之后才能正常使用。

mount [参数]  /dev/sdb1(需要挂载的分区) /sdb1(挂载目录)

94.unmount

---

 umount [-ahnrvV][-t <文件系统类型>][文件系统]umount /AAA/BBBB/CCC

95.iconv

Linux下iconv命令对文件编码进行转换_shimadear的博客-CSDN博客_iconv iso-8859-1

iconv -f sjis -t utf8 yourFileName

---

2022想定外パターンで検索時、wcにパイプしない、そのまま出力する。// 2021年末,YYYY的Bug有无确认。

2021-12:grep '\"2021\-12' ./*.csv | wc
2022-12:grep '\"2021\-12' ./*.csv | tail -3 | xargs iconv -f sjis -t utf8

---

96.tcpdump

tcpdump -i any dst host aa.bbb.ccc.com -s0 -A
tcpdump –i eth0 ’port 1111‘ -X -c 3

97.★★★ 实际应用  ★★★ 【if else】【字符串包含】【字符串比较】

功能:根据文件包含的字符,文件名,文件后缀,来判断文件类型

注意:

 ・等于号两边要有空格

 ・=~ 可以判断是否包含某个字符串 // abc* 虽然也可以判断,但并不是所有的shell都好用

 ・  ;then 写在了一行,如果不写分号,then可以换行写 // 分号 ;  起到了换行的作用

 ・变量定义 可以时 $FILE_NAME  也可以是 ${FILE_NAME}

  (如果有两个变量 【FILE_NAME】  【FILE_NAMEA】 )

         echo  ${FILE_NAME}A

・定义字符串时,字符串没有空格,那么有没有引号"的效果都是一样的

・两个括号,[[ expression ]]   // 双方括号命令提供了针对字符串比较的高级特性

if [[ "${FILE_NAME}" =~ "abc" ]] ; thenFILE_TYPE="abc"
elif [[ "${FILE_NAME}" == "aaa" ]] ; thenFILE_TYPE="aaa"
elseFILE_TYPE=`echo ${FILE_NAME} | awk -F "." '{print $2}'`
fi

96.time  查看命令性能 (不同于 windows 的time)

97.locale

   查看系统默认编码


 

sxz001@sxzap01:~$ locale
LANG=ja_JP.UTF-8
LANGUAGE=
LC_CTYPE="ja_JP.UTF-8"
LC_NUMERIC="ja_JP.UTF-8"
LC_TIME="ja_JP.UTF-8"
LC_COLLATE="ja_JP.UTF-8"
LC_MONETARY="ja_JP.UTF-8"
LC_MESSAGES="ja_JP.UTF-8"
LC_PAPER="ja_JP.UTF-8"
LC_NAME="ja_JP.UTF-8"
LC_ADDRESS="ja_JP.UTF-8"
LC_TELEPHONE="ja_JP.UTF-8"
LC_MEASUREMENT="ja_JP.UTF-8"
LC_IDENTIFICATION="ja_JP.UTF-8"
LC_ALL=
sxz001@sxzap01:~$

相关联内容 

  JVM运行时,不知道编码,默认使用系统编码
  java -Dfile.encoding=UTF-8 XXX.java

locale    英[ləʊˈkɑːl]    n. 场所,现场
locate    英 [ləʊˈkeɪt]   v. 位于;定位,找出…的准确位置;定居

98.native2ascii    (转换 \uXXXX  unicode )

native2ascii -reverse yourUxxxFileName 

reverse  v. 颠倒,倒转;倒退;逆转;调换

99.zcat

可以直接查看【xxxx.gz】文件中的内容。(无需解压)

---

100.perl

UNIX平台下历史悠久的脚本语言,擅长基于正则表达式的文本处理。

例:把Linux换行,变为Windows换行

perl -p -e 's/\n/\r\n' /XXX/XXX/a.txt > /XXX/XXX/b.txt

perl参数
-e 执行命令,也就是脚本
-p 自动循环+输出,也就是while(<>){命令(脚本); print;}

===

101.curl

curl  //Liunx中,比windows中,有更多参数可以使用

https认证使用

curl -k -v -F "key1=valuse1" -F "key2=value2" https://xxxx.xxx/aaa/bbb

各个参数介绍

// F:Form         模拟用户在浏览器上点击“submit”按钮提交表单的操作。 比如,要提交存储密码的文件到服务器上,命令为:curl -F password=@/etc/passwd
 
// k:               接受服务器的ssl证书而不管合不合法。参数“-k”等同于“--insecure”。
 
// v:verbose     显示一次 http 通信的整个过程,包括端口连接和 http request 头信息。

参数 -k   忽略证明书认证  (在Linux系统中,curl 有这个参数)

       -k, --insecure
              (TLS) By default, every SSL connection curl makes is verified to be secure. This option allows curl to proceed and  oper乚
              ate even for server connections otherwise considered insecure.
 
              The  server  connection is verified by making sure the server's certificate contains the right name and verifies success乚
              fully using the cert store.
              See this online resource for further details:
               https://curl.haxx.se/docs/sslcerts.html
              See also --proxy-insecure and --cacert.

登录使用

curl -u 'bob:12345' https://google.com/login

参数 -U  

-u参数用来设置服务器认证的用户名和密码curl -u 'bob:12345' https://google.com/login
上面命令设置用户名为bob,密码为12345,
然后将其转为 HTTP 标头Authorization: Basic Ym9iOjEyMzQ1

指定客户端证明书

curl --cert client.crt  --key client.key --insecure https://此处添加自己的网址及端口

参数 m 指定超时等待时间

 curl -I -m 5 hostName

curl的错误类型

curl: (6) Could not resolve host - 无法解析主机名或域名。
curl: (7) Failed to connect to localhost po

除此之外,在使用curl命令时,可能会遇到以下错误类型:

错误代码 1:表示无法连接到远程主机。
错误代码 2:表示无法读取本地文件或无法打开本地文件。
错误代码 3:表示无法执行指定的命令。
错误代码 4:表示FTP服务器返回一个错误代码。
错误代码 5:表示无法解析URL或使用了无效的协议。
错误代码 6:表示无法解析主机名。
错误代码 7:表示连接被拒绝。
错误代码 22:表示服务器返回了一个错误的HTTP状态代码。
错误代码 28:表示连接超时或操作超时。
错误代码 56:表示接收到了一个无效的响应头。
这些错误类型可能会因为不同的原因而出现,例如网络连接问题、文件权限问题、服务器配置问题等等。在遇到错误时,可以根据错误代码来确定具体的原因,并尝试解决它。

====

102.set

主要对于 IBM的AIX Server,需要执行下面命令,如果不执行,key【Backspace】不好用。

set -o emacs

----

103.openssl

 ・目的:

从xxxx.p12文件(客户端证明书的密码)中,生成「crt file」、「key file」供Postman、HttpClient的代码使用

(旧版本Postman无法使用 xxx.p12, 需要使用 crt 和key者两个文件)
(HttpClient的代码,也使用这两个文件)

(在Linux或者AIX Server中,都有openssl这个命令)


导出公钥(证书)(crt)

openssl pkcs12 -in YourCert.p12 -clcerts -nokeys -out cert.crt

输入YourCert.p12的密码

导出秘钥(key)

openssl pkcs12 -in YourCert.p12 -nodes -nocerts -out private_key.key

输入YourCert.p12的密码

(选项-nodes不是英文单词“nodes”,而是“no DES”。 当作为参数给出时,这意味着OpenSSL不会encryptionPKCS#12文件中的私钥)

xxx

104.特殊符号【~】

代表当前登录用户的用户目录,
经常和「ssh sftp」命令一起使用,使用公钥登录其它系统
比如

ssh -i ~/.ssh/id_rsa_XXX userXXX@serverXXX  "mkdir -p /Work/Test/test001"

登录 @serverXXX 服务器, 创建文件夹

====

105.sftp之参数【-b】

-b batchfile

  Batch mode reads a series of commands from an input batchfile instead of stdin.

echo "put -r /XXX/XXX/xx1 /Work/XXX/XXX/xx1" > sftp_input
echo "put -r /XXX/XXX/xx2 /Work/XXX/XXX/xx2" >> sftp_input
sftp -i ~/.ssh/id_rsa_XXX -b sftp_input userXXX@serverXXX 

xxx

106.date

显示示【秒数】对应的【时间】 (<秒数> 是指从 1970 年 1 月 1 日至今的秒数)

date -d @1609459200

显示,从 1970 年 1 月 1 日至今的秒

date +%s
 

107.sh -xe 参数是什么意思

sh -xe 是一种 shell 命令的参数组合,它有以下含义:

-x:在执行每条命令之前,输出该命令及其参数
-e:如果任何命令返回非零状态(即错误状态),则立即退出 shell
因此,使用 sh -xe 命令可以在执行脚本时,输出每个命令的执行情况,并在遇到错误时立即停止脚本的执行。这对于调试脚本和快速发现问题非常有帮助。
 

108.grep 查询不到时, 也能返回 0

对应其它命令,下面这种方式也适用

grep "pattern" file || echo 0

109.base64

查看base64编码对应的内容

echo 'YmFzZTY0IGVuY29kaW5n' | base64 -d

xxx

110.bc

bc 是 "Basic Calculator" 的缩写,是一种用于执行数学运算的命令行计算器程序。

===
在 Linux 中,您可以使用命令行计算器 bc 来直接计算数字。以下是使用 bc 进行简单计算

===
在 Linux 中,退出 bc(一个用于计算器的命令行工具)的方法是输入 quit 或 exit 命令,然后按下回车键。这将使 bc 停止并返回到命令行提示符

xxx

111.known_hosts 中  ssh-rsa 的值 是根据什么生成的

known_hosts 文件中的 ssh-rsa 值是根据远程主机的公钥生成的。当您第一次连接到一个远程主机时,您的SSH客户端会将该主机的公钥保存在known_hosts文件中。每次连接到该主机时,SSH客户端都会验证该主机的公钥是否与known_hosts文件中的相同,以确保您正在连接到正确的主机。如果公钥【密钥指纹信息】不匹配,SSH客户端会发出警告并停止连接。这有助于保护您的计算机免受中间人攻击。

====

known_hosts 文件不存储服务器的公钥信息。known_hosts 文件是用来存储已知主机的密钥指纹信息,以便在与主机建立 SSH 连接时进行验证。

当你首次连接到一个 SSH 服务器时,你的 SSH 客户端会将服务器的公钥指纹保存在 known_hosts 文件中。下一次连接时,客户端会比对服务器的公钥指纹和 known_hosts 文件中相应条目的指纹是否一致,以确保你连接的是同一个已知主机,以防止中间人攻击。

因此,known_hosts 文件只保存服务器的公钥指纹信息,而不是完整的公钥信息。公钥信息通常可以在服务器的证书中找到。

===

主机的公钥和主机的公钥指纹是密切相关但含义略有不同的概念。

--

主机的公钥是在SSH通信中用于进行加密和验证的一对密钥对中的公钥部分。它是由主机生成并提供给客户端,供客户端用来加密数据并验证主机的身份。主机的公钥是一个较长的字符串,通常以SSH格式开头,例如"ssh-rsa AAAAB3NzaC1yc......"。

---

主机的公钥指纹是主机公钥经过特定算法(如MD5、SHA-256等)计算得到的一个较短的唯一标识。它是用于验证主机公钥的有效性,并用作主机身份的摘要信息。公钥指纹通常是一个以冒号分隔的十六进制字符串,例如"de:ad:be:ef:12:34:56:78:90:ab:cd:ef:12:34:56:78"。

---

区别在于公钥是主机提供给客户端用于加密和验证的长字符串,而公钥指纹是根据公钥计算得到的短字符串,用于在第一次连接时验证主机身份的有效性。公钥用于实际的加密和验证过程,而公钥指纹用于验证公钥的有效性和一致性。

==

==

xxx

112.如何查看主机的公钥信息

cat /etc/ssh/ssh_host_rsa_key.pub

xxx

===

这个文件是如何生成的,

/etc/ssh/ssh_host_rsa_key.pub 文件是 SSH 主机的 RSA 公钥文件,它是在 SSH 服务器首次安装时自动生成的。在 SSH 服务器配置中,你可以定义要生成的密钥类型和文件路径。

这个公钥文件包含了 SSH 服务器的公钥信息,用于向连接到该服务器的客户端验证身份。

====

113.shell 中 ${0##*/} 是什么意思-----获取脚本文件的名称

在shell中,${0##*/}是一种参数替换的用法,其作用是获取脚本文件的名称。


具体解释如下:

0
表示当前脚本的名称,即
0表示当前脚本的名称,即0是一个内置的变量,它会保存当前执行的脚本的名称。

##是一种模式匹配操作符,表示删除匹配的最长字符串。

*/表示任意字符和路径分隔符("/")的组合。


所以,{0##*/}的含义是从0中删除最长的以"/"为分隔符的字符序列。


举个例子,如果当前的脚本文件的路径和名称是"/path/to/script.sh",那么${0##*/}会删除"/path/to/",只返回"script.sh"作为结果

xxx

114.hostname

在管理员权限下,使用下面命令可以直接修改主机名字

hostname newhostname

这种方式修改,只是临时修改,如果服务器重启,会变回旧的名字

也就是说这个命令不仅能查看主机信息,还能修改主机信息!!!

115.printf

#!/bin/bash
logInfo() {# %-60s 格式为左对齐且宽度为60的字符串代替('-'表示左对齐),不使用则默认右对齐。printf "%s%-60s%s\n" "`(date '+%Y-%m-%d %T')`[INFO] " "$1" "$2"
}logInfo "MessageXXXXXXXXX" "ITEM_XXXXX"
logInfo "MessageXXXXXXXXXaaaa" "ITEM_XXXXX"

========

xxx

116.特殊符号【^M】【 ^!】 等等这些转义字符,以及其含义

在Linux中,^M和^!都是特殊字符,表示对应的控制字符。它们的含义如下:

・^M(Ctrl+M):回车符(Carriage Return)。在Unix/Linux系统中,行结束符通常是换行符(n),而在Windows系统中,行结束符是回车换行符(rn)。因此,当从Windows系统复制文本到Linux系统时,可能会带有^M字符,需要将其删除或转换为换行符。 转义字符:r

ーーーーーーーーーーーーーーーーーーーーー

・^!(Ctrl+!):表示ASCII码为33的字符。在Linux系统中,它没有特殊含义,通常被视为普通字符。可以直接在命令行或文本中使用。

需要注意的是,这些控制字符在不同上下文中可能会有不同的用途和含义。因此,在使用时要根据具体情况进行处理,以确保达到预期的效果。

xxx

在Linux中,除了上面提到的^M和^!之外,还有一些其他的特殊字符需要使用^进行表示,它们的含义如下:

^A(Ctrl+A):表示ASCII码为1的字符。在命令行和文本编辑器中,表示光标移动到行首。
^B(Ctrl+B):表示ASCII码为
2的字符。在命令行和文本编辑器中,表示光标向左移动一个字符。
^C(Ctrl+C):表示ASCII码为
3的字符。在终端中,按下Ctrl+C可以中断当前正在执行的程序或命令。
^D(Ctrl+D):表示ASCII码为4的字符。在终端中,按下Ctrl+D表示输入结束,可以触发终端的文件结束符(EOF)。
^E(Ctrl+E):表示ASCII码为5的字符。在命令行和文本编辑器中,表示光标移动到行尾。
^F(Ctrl+F):表示ASCII码为6的字符。在命令行和文本编辑器中,表示光标向右移动一个字符。

还有一些其他的特殊字符也可能通过使用^进行表示,具体取决于使用的软件和上下文环境。在终端中,一些控制字符可能会被解释为特殊功能,因此在使用时需要注意。

117.XXX

xxx

118.XXX

xxx

119.XXX

xxx

■AIX

1.查看端口对应的进程 (Websphere Server)

      > netstat -Aan | grep 56789  // your port 56789
XXXXXXXXXX tcp   0  0  *.56789   *.*  LISTEN

      > rmsock XXXXXXXXXX tcpcb
XXXXXXXXXX is being held by process NNNNNNN (java.)  // PID NNNNN

      > pl -elf  | grep NNNNNNN
XXXXXXXXXXXXXXXXXXXX...    xxxCellxxxnode   xxxxServerxxx
      

====

2. shell  // AIX切换壳 

AIX操作系统,模式的壳是ksh,换一个壳(shell),即可实现tab自动补全,↑↓查看前后命令

如何换壳,直接执行下面的命令即可

shell

xxxx

3.rm 删除文件

-e 相当于 Linux中的 -v: 显示文件删除后的信息

-e   Displays a message after each file is deleted.

rm -fre

4.csum

csum -h SHA1 FileName.txt

5.find運用(AIX)

find /AAA/BBB -type f | sort | xargs sum

====

// フォルダも表示する。 p:フォルダ表示時、末尾「slash」も表示する。「/AAA/BBB/aaa/」
find /AAA/BBB | sort | xargs ls -lpd

6.istat   查看文件最新修改时间

istat 查看文件最新修改时间 //Purpose: Examines i-nodes

last updated:  xxxx    // chmod chown 命令会影响此时间
last modified: xxxx    // chmod chown 命令  或者 修改文件内容会影响此时间
last accessed: xxxx    // cat等命令会影响此时间


purpose  [ˈpɜːrpəs] n. 目的;意志;用途;意义
examine  [ɪɡˈzæmɪn] v. 调查;诊察;检查;检测;考试;审问
 

===

7.AIX 查看用户上一次登录・用户是否被锁

/etc/security/lastlog

注意:这个文件里面显示的时间是,秒数。(<秒数> 是指从 1970 年 1 月 1 日至今的秒数)

这里面有两个时间

  time_last_login

  time_last_Unsuccessful_login

==

在Linux中,可以使用【date -的@1691713543】查看秒数对应的时间

===

Linux并没有上面的文件,使用下面命令,查看用户

passwd -S YourUserID

在上面的【18.passwd】中查看详细

==

8.在 AIX 系统中,如果没有安装 unzip 命令,可以尝试使用以下命令解压缩 Zip 文件:

使用 jar 命令:

jar -xvf filename.zip

xxx

9.查看磁盘容量

进入要查看的目录
cd /AA/BB
查看当前目录,磁盘使用情况
df -m .
查看当前目录下,站容量最多的7个目录
du -sm ./*|sort -nr|head -n 7

xxx

10.查看字符对应的16进制编码 【od】 (linux 也能用) 

echo "a" | od -t x1

xxx

echo "ー" | od -t x1

==

SJIS(Shift-JIS)和EUC-JP(Extended Unix Code-JP)是两种常用的日语字符编码方案。

  1. 字符集范围:

    • SJIS:由日本电脑制造商开发,支持日语中的大部分字符,包括假名、汉字、罗马字等。
    • EUC-JP:也是由日本开发,与SJIS类似,支持日语字符集,包括假名、汉字、罗马字等。
  2. 编码方式:

    • SJIS:采用双字节编码方式,每个字符占用2个字节,其中第一个字节的范围是0x81-0x9F和0xE0-0xFC,第二个字节的范围是0x40-0xFC。
    • EUC-JP:同样采用双字节编码方式,每个字符也占用2个字节,第一个字节的范围是0xA1-0xFE,第二个字节的范围也是0xA1-0xFE。
  3. 兼容性:

    • SJIS:在Windows系统中广泛使用,支持大部分的软件和应用程序。
    • EUC-JP:在Unix/Linux等操作系统中常用,也有一些应用程序和工具支持该编码。
  4. 其他区别:

    • SJIS有时会产生字节流冲突的问题,因为某些字符在不同的上下文中有不同的编码,这可能导致乱码或无法正确解码。
    • EUC-JP在一些应用中可能会有更好的兼容性和处理效果。

总的来说,SJIS和EUC-JP都是常见的日语字符编码方案,具有相似的字符集支持,但在具体的应用环境和兼容性方面可能有一些差异。选择哪种编码方案应基于具体的需求和应用场景进行判断。

====

编码通过下面方式指定

 ===

xxxx

11.last【用于显示登录和注销的用户会话记录】

打开系统的登录日志文件,通常是/var/adm/wtmp文件。您可以使用以下命令查看该日志文件的内容:

last

该命令会列出最近的用户登录和注销记录。每行记录都会显示用户名、登录日期和时间、登录的IP地址(如果适用),以及注销的日期和时间(如果用户使用了exit命令退出)。如果用户没有使用exit命令退出,那么注销的日期和时间可能为空。

==

在AIX系统中,last命令用于显示登录和注销的用户会话记录。以下是如何使用last命令的基本语法:

last [选项] [用户名] [终端]

一些常用的选项包括:

  • -a:显示终端名称。
  • -d:显示终端断开连接的时间。
  • -F:以完整的日期和时间格式显示记录。
  • -R:以相对时间格式显示记录。
  • -s:显示指定日期/时间之后的记录。

下面是一些示例:

  1. 显示所有用户的登录和注销记录:
last
  1. 显示指定用户的登录和注销记录:
last username

将"username"替换为您要查看的特定用户名。

  1. 显示指定终端的登录和注销记录:
last -t tty1

将"tty1"替换为您要查看的特定终端。

  1. 显示指定日期/时间之后的记录:
last -s "YYYY-MM-DD HH:MM:SS"

将"YYYY-MM-DD HH:MM:SS"替换为您指定的日期和时间。

  1. 显示完整的日期和时间格式的记录:
last -F

请注意,要使用last命令,您需要以root账户或具有足够权限的账户登录到AIX系统。此外,AIX系统中的登录日志通常存储在/var/adm/wtmp文件中。

xxx

12.输出文件 无行换 (AIX ksh壳下面) 【\c】

echo '20231013\c'

xxx

13.nslookup  获取给定IP地址的服务器名称

nslookup <IP地址>

或者

host <IP地址>

这些命令会查询DNS服务器,并返回与给定IP地址关联的主机名。请确保在运行命令之前,已经正确配置了DNS服务器。

xxx

14.prtconf 查看系统设置

查看 内存大小(不过从结果来看,像是磁盘容量,不像是内存容量)
prtconf | grep MB 

xxx

15.【rmsock】 AIX根据端口号,查找PID

windows可以用命令netstat -ano来查端口对应的进程的pid.
aix却并不能,aix需要使用下面的命令过程:

●Step1
netstat -Aan | grep 1334
===============
f10002000043c398 tcp4 0 0 *.1334 *.* LISTEN
===============

●Step2
rmsock f10002000043c398 tcpcb
===============
The socket 0x43c008 is being held by proccess 217248 (writesrv).
===============

●Step3
ps -elf | grep 217248

=============================================

详见【74.1.netstat、rmsock  (AIX)】

xxx

16.svmon 【AIX中 类似 Linux系统中 free 的命令】

svmon -G -O unit=GB

--

 $ svmon -G  -O unit=GB,timestamp=on  
[oracle@guangdong_rac1 ~]$svmon -G  -O unit=GB,timestamp=on
Unit: GB                                                   Timestamp: 14:40:29
-------------------------------------------------------------------------------size       inuse        free         pin     virtual  available
memory       249.50      216.28        33.2        35.3        84.2     116.82
pg space       8.00        0.20work        pers        clnt       other
pin            27.0           0        0.01        8.30
in use         84.2           0      132.12

----

size:工作集的逻辑页面大小
inuse:已经被分配的页面数
free:可用的空闲页面数
pin:锁定的页面数
virtual:虚拟页优先级LRU链表的比例
mmode:工作模式下的可能的最大页面数
memclient:佔用内存的客户数量
memory:实际内存的大小
pool:  内存池的大小

xxx

17.【du】查看某个目录,容量占用多的文件夹

du -sg /DATA/* | sort -rn | head -n 10

xxx

查看当前目录下,站容量最多的7个目录
du -sm ./* | sort -nr | head -n 7

g和m应该代表容量单位 GB MB

===

18.【df】查看===文件系统===的=磁盘===使用情况,百分比

df -g /DATA

(Linux不支持这个参数, AIX中,是 GB 单位显示 的意思)
(df /DATA)这种方式,只显示  /DATA 的信息

即,mount命令查看出的磁盘

===

19.LInux 的 du 和 dh 命令的区别

xxx

du命令和dh命令都是用于检查磁盘空间使用情况的Linux命令,但它们之间有一些区别。

  1. du命令(磁盘使用量):du命令用于显示目录中文件子目录的磁盘使用空间。它递归地检查指定目录及其所有子目录,并返回每个文件和目录的磁盘使用量。du命令默认以字节为单位显示使用量,可以使用"-h"选项以人类可读的形式(如KB、MB)显示使用量。

  2. df命令(磁盘空间 disk free):df命令用于显示文件系统的磁盘空间使用情况。它列出文件系统的名称、容量、已使用空间、可用空间和挂载点等信息。默认以"K"为单位显示容量和使用量,也可以使用"-h"选项以人类可读的形式显示。

总结:

  • du命令用于检查目录中文件和子目录的磁盘使用空间。
  • df命令用于显示文件系统的磁盘空间使用情况。 所以,它们的主要区别在于du命令是显示目录和文件的使用量,而df命令是显示文件系统级别的磁盘空间使用情况。

==

20.

xxx

21.

xxx

22.

xxx

23.

xxx

■其它

1.AIX 无法补全的原因

AIX如何实现tab键自动补全命令-百度经验

检查AIX操作系统root使用的shell,发现为ksh,需要修改为bash,换一个壳,即可实现tab自动补全
(注:Linux默认创建shell为bash,所以Linux可以自动补全)

检查・变更

cat /etc/passwd | grep root

root:!:0:0::/root:/user/bin/ksh

root:!:0:0::/root://bin/bash

2.sh 与 ksh

以 #!/bin/ksh  开头

使用 sh 执行 一个 以 #!/bin/ksh  开头的 ksh 文件,到底是 ksh 执行 ,还是 sh 执行

如果你使用sh来执行一个以#!/bin/ksh开头的ksh文件,实际上还是由ksh来执行。这是因为在脚本中指定了解释器路径,即#!/bin/ksh,所以系统会使用ksh来解释和执行文件内容,而不是使用sh。

使用 sh 执行 一个 以 #!/bin/ksh  开头的 sh 文件,到底是 ksh 执行 ,还是 sh 执行

如果你使用sh来执行一个以#!/bin/ksh开头的sh文件,实际上还是由ksh来执行。这是因为在脚本中指定了解释器路径,即#!/bin/ksh,所以系统会使用ksh来解释和执行文件内容,而不是使用sh。

介绍几个 sh 与 ksh 语法之间的区别

当使用sh和ksh来执行脚本时,可能会遇到一些语法方面的差异。以下是一些sh和ksh之间可能存在的语法区别:

  1. 数组赋值:

    • 在sh中,数组赋值不是直接支持的,通常会使用间接方式来模拟数组。
    • 在ksh中,可以直接使用数组并进行赋值和访问。
  2. 命令替换:

    • 在sh中,使用 `command` 来进行命令替换。
    • 在ksh中,也可以使用 `command`,同时也支持 $(command) 的形式来进行命令替换。
  3. 变量声明与赋值:

    • 在sh中,变量赋值时不需要使用关键字declare或typeset。
    • 在ksh中,可以使用declare或typeset关键字来声明变量,并指定变量的属性。
  4. 算术运算:

    • 在sh中,可以使用expr或者$(( ))来进行算术运算。
    • 在ksh中,也支持expr和$(( )),同时还可以使用let来进行算术运算。

这些是一些可能存在的sh和ksh语法上的区别,实际上语法的差异还可能更多。在编写脚本时,建议查阅相关的文档或者参考书籍,以了解具体的差异并编写兼容性更好的脚本。

---

■更多命令

【Linux】一步一步学Linux系列教程汇总(更新中......)_嵌入式开发工程师---欢迎大家一起交流-CSDN博客_csdn dengjin

---

这篇关于Unix_Linux_AIX_常用命令总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/772523

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

二分最大匹配总结

HDU 2444  黑白染色 ,二分图判定 const int maxn = 208 ;vector<int> g[maxn] ;int n ;bool vis[maxn] ;int match[maxn] ;;int color[maxn] ;int setcolor(int u , int c){color[u] = c ;for(vector<int>::iter