码迷,mamicode.com
首页 > 系统相关 > 详细

Linux中的一些点

时间:2019-12-14 09:51:47      阅读:95      评论:0      收藏:0      [点我收藏+]

标签:mys   work   www   打包   template   单引号   har   bin   顺序   


前言

本文记录一些日常使用linux的一些点。

系统负载评估

理解Linux系统负荷

查看 ps -ef

[root@deployer ~]# ps -ef
UID        PID  PPID  C STIME TTY          TIME CMD
root         1     0  0  2018 ?        00:00:29 /usr/lib/systemd/systemd --system --deserialize 21
root         2     0  0  2018 ?        00:00:00 [kthreadd]
root         3     2  0  2018 ?        00:00:00 [ksoftirqd/0]
root         5     2  0  2018 ?        00:00:00 [kworker/0:0H]
root         9     2  0  2018 ?        00:00:40 [rcu_sched]
......
root       337     2  0  2018 ?        00:00:01 [kworker/3:1H]
root       380     1  0  2018 ?        00:00:00 /usr/lib/systemd/systemd-udevd
root       415     1  0  2018 ?        00:00:01 /sbin/auditd
root       498     1  0  2018 ?        00:00:03 /usr/lib/systemd/systemd-logind
......
root@pts/0
root     32794 32792  0 Jan10 pts/0    00:00:00 -bash
root     32901 32794  0 00:01 pts/0    00:00:00 ps -ef

三类进程

  1. pid=1 init进程Systemd
  2. pid=2 内核线程kthreadd,用户态不带中括号, 内核态带中括号
  3. tty 带问号的,说明不是前台启动的,一般都是后台启动的服务

Linux中的引号

首先,单引号和双引号,都是为了解决中间有空格的问题。

  • 单引号

    当shell碰到第一个单引号时,它忽略掉其后直到右引号的所有特殊字符

  • 双引号

    双引号只要求忽略大多数,具体说,括在双引号中的三种特殊字符不被忽略:美元符号,反斜杠和反引号

  • 反引号

    命令替换:在执行一条命令时,会先将其中反引号之间的语句,或者是$()中的语句当作命令执行一遍,再将结果加入到原命令中重新执行。其中,$()格式受到POSIX标准支持,也利于嵌套。比如docker rm -f $(docker ps -aq)。常见的用法:将命令的输出结果赋给一个变量

      var=`command`
    

软件包安装工具

  • rpm & yum 后者可以解决依赖关系
  • dpkg & apt 后者可以解决依赖关系

pid文件

  • pid文件内容:pid文件为文本文件,内容只有一行, 记录了该进程的ID。

  • pid文件作用:防止进程启动多个副本。只有获得pid文件(固定路径固定文件名)写入权限(F_WRLCK)的进程才能正常启动并把自身的PID写入该文件中。其它同一个程序的多余进程则自动退出。

/etc/issue和/etc/motd

登陆linux的欢迎界面可由/etc/issue和/etc/motd控制。/etc/issue文件的使用方法与/etc/motd文件相差不大,它们的主要区别在于:当一个网络用户或通过串口登录系统上时,/etc/issue的文件内容显示在login提示符之前,而/etc/motd内容显示在用户成功登录系统之后。

socket文件

socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是UNIXDomain Socket。虽然网络socket也可用于同一台主机的进程间通讯(通过loopback地址127.0.0.1),但是UNIX Domain Socket用于IPC更有效率:不需要经过网络协议栈,不需要打包拆包、计算校验和、维护序号和应答等,只是将应用层数据从一个进程拷贝到另一个进程。这是因为,IPC机制本质上是可靠的通讯,而网络协议是为不可靠的通讯设计的。UNIX Domain Socket也提供面向流和面向数据包两种API接口,类似于TCP和UDP,但是面向消息的UNIX Domain Socket也是可靠的,消息既不会丢失也不会顺序错乱。

UNIX Domain Socket是全双工的,API接口语义丰富,相比其它IPC机制有明显的优越性,目前已成为使用最广泛的IPC机制,比如X Window服务器和GUI程序之间就是通过UNIX Domain Socket通讯的。

来源于:[本地socket unix domain socket][]

socket文件,只有在本级通信(AF_UNIX)时才会用到;对于远程TCP通信(AF_INET)来说,是不存在sock文件一说的。以mysql.sock文件为例,假定AB两台主机,mysql服务运行在B主机上。

  • 那么对于A主机来说,访问mysql服务只能通过ip:port的方式。
  • 对于B主机上程序来说,访问mysql服务除了通过localhost:port外,还可以通过socket文件方式。后者的好处是:如果通过mysql.conf更改mysql的服务端口,那么mysql服务重新启动时将生成新的socket文件,对于程序来说,不用做任何改变。而前者则需要改变程序中的端口设置。

另外,指定socket文件url一个例子:unix:///home/docker/docker.sock,其中unix://类似于tcp://,后面的大专栏  Linux中的一些点de class="highlighter-rouge">/home/docker/docker.sock表明socket文件的路径。

某些linux应用运行前,我们要为其配置监听的ip和端口,而支持sock文件后,我们只需为其配置sock文件即可,比如:

$ sudo /usr/bin/docker –d –H unix:///home/docker/docker.sock &

而docker client在访问docker daemon时,需要:

$ docker –H unix:///home/docker/docker.sock ps –a

rsync

负责进行文件同步的

rsync -vzrtopgu --delete dir_path1 dir_path2

注意,dir_path1中的改变都会被同步到dir_path2中,但是,如果dir_path2改变,并且dir_path2在命令中的先后顺序不变的话,其改变不会被同步到dir_path1中。也就是说,这种同步是单向的,以dir_path1为准。

source和. 命令##

有两种方法执行shell scripts:

  1. 一种是新产生一个shell,然后执行相应的shell scripts
  2. 一种是在当前shell下执行,不再启用其他shell

假设一文件file,文件内容为echo "test!!!!!!!!!!!!!!!!!!!!!":

  1. 没有可执行权限

1.1. ./file 输出Permission denied

1.2. . ./file 执行成功

1.3. source file 执行成功

  1. 具有可执行权限,file添加一行为a=test

2.1 ./file;echo $a 输出”test!!!!!!!!!!!!!!!!!!!!!”`,没有输出$a

2.2 . ./file;echo $a he source file;echo $a则都输出

./file中的点代表当前路径的意思,会产生一个新的子shell来执行file,也即file中如果设置环境变量,当前shell无法得到。子shell可以继承父shell的环境变量值。与此同时,file必须具有可执行权限。

. ./file中第一个点,代表source,第二个点代表当前路径。file不需要具备可执行权限,file中的所有指令将在当前shell中执行。也即如果file设置环境变量,当前shell也能感知到。

一次创建多个文件夹

mkdir -p /etc/confd/{conf.d,templates}

创建并管理自己的后台程序

/sbin/start-stop-daemon

inotifywait

监控某个文件或目录的改变

expect

进行自动化的人机交互,对于设定好的特定匹配形式,以相匹配的动作以应对。

测试某个远程主机的特定端口是否开放

  1. telnet

    在终端使用者的电脑上使用telnet程序,用它连接到服务器。终端使用者可以在telnet程序中输入命令,这些命令会在服务器上运行,就像直接在服务器的控制台上输入一样。

    • 使用telnet操作192.168.56.153上的redis服务

        user@ubuntu:~$ telnet 192.168.56.153 6379
        Trying 192.168.56.153...
        Connected to 192.168.56.153.
        Escape character is '^]'.
        get name
        $3
        lqk
      
    • 直接在192.168.56.153上操作redis

        user@ubuntu:~$ redis-cli get name
        "lqk"
      
    • 退出telnet

      1. ctrl + ]
      2. telnet > quit // 回车
  2. 使用nc命令

     user@ubuntu:~$ nc -z 192.168.56.153 6379
     user@ubuntu:~$ echo $?
     0
    

    返回1 表示连接失败(或者说,端口没有开启)

引用

本地socket unix domain socket

让进程在后台可靠运行的几种方法


Linux中的一些点

标签:mys   work   www   打包   template   单引号   har   bin   顺序   

原文地址:https://www.cnblogs.com/lijianming180/p/12037848.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!