1. rsync经过服务同步
启动服务linux
注意u:端口修改了,须要重启shell
启动服务vim
检测一下他有没有启动服务.,出现daemon说明启动了。windows
查看监听的端口命令:netstat -lntp缓存
为了更好的把握服务的同步安全
建立一个rsync目录bash
同步一个tmp目录下1的文件,同步到192.168.133.132 ,冒号后面是模块的命令,【test】:test是模块网络
查看模块的名字,root就是模块的名字。把list改为list=false就能够不显示模块名,隐藏了。命令:vim !$,执行上一个命令。命令:rm -rf rsync*能够删除全部的rsync文件。fg命令是调出上一条命令。上一个命令是vi,fg就能够直接进入vi编辑模式。session
nobody的提示是写入不了。less
把/tmp/test/目录,同步到机器192.168.52.130的test目录下。
同步。。把/tmp/1文件,同步到ip地址为192.168.122.1的机器上的wxz.txt中。
注释掉密码,就是把uid,gid后面的面容写成root,同步时,就不用输入密码了,命令:cat /etc/rsyncd.conf
不用密码同步成功了,两个冒号表明的是用的是rsyncd.conf文件。(这是两种写法)
查看同步成功吗
查看日志
在当前目录下建立一个软链接,./表明的当前目录。软连接名字叫12.txt
同步一个目录,
删除全部的test文件,再同步。
使用命令rsync -avLP 192.168.122.1::test/ /tmp/test/,同步。
查看日志,命令cat /var/log/rsync.log
报错缘由,chroot=true
把源文件拷贝过来了
在服务端上,同步的时候,没有密码不安全,查看密码存放的目录,使用命令vi /etc/rsyncd.conf。
最底下的添加密码/etc/rsync.passwd就是密码文件,命令:vim /etc/rsync.passwd,设置一个权限,命令:chmod 600 !$.
test后面是密码。
注意:在客户端上只写一个密码就好了。
同步的时候添加,--password-file=/etc/rsync_pass.txt 。
常见问题:ip地址错误。使用命令:netstat -lntp查看ip地址。
出现两个错误。解决办法。telnet是检测端口是否通的命令;。
端口不通
先检查一下iptables的问题,命令:iptables -nvL,, ,结果iptables出问题了.
关掉防火墙
而后使用telnet,显示已经通了,没问题了。
退出来。按ctrl+】,而后quit.
同步了
注释掉密码
注意:不使用ssh传输,也不使用服务同步,使用rsync命令同步,
远程传输时,若是我不开启rsyncd的daemon,使用rsync命令传输时也不添加-e "ssh -p 22" 参数,那么默认也是使用22端口进行传输
重点:默认一个冒号就是使用ssh同步的。
2. linux系统日志
logrotate 使用详解:https://my.oschina.net/u/2000675/blog/908189
- /var/log/messages总的日志
实例:
ls /var/logrotate.conf查看系统的总的日志。,使用less !$查看一下内容。du -sh !$查看系统日志的大小,
查看被切割的日志,使用命令:ls /var/log/messaages*,查看全部的日志。
切割日志的服务logrotate,,,datexxt是日志的后缀名,就是日期。
查看cat /etc/logrotate.d下的配置文件,
查看系统总日志的大小
查看syslog下的日志文件。
查看硬件方面的日志,保存在内存中,命令:dmesg, dmesg -c清空,重启系统以后,就会再次显示。
查看dmesg日志,是一个系统启动的日志,与上面的dmesg命令无关。
查看dmesg日志信息
last查看正确的登陆历史
last调用的日志是wtmp日志,这个日志是一个二进制目录,不能直接查看。last能够查看二进制文件
lastb查看登陆失败的用户
lastb依赖与btmp日志,都是是一个二进制目录,不能直接查看
查看安全日志secure
三、screen工具
screen就是一个虚拟终端,当咱们进入以后,就能够当成是一个终端啊。 在这个终端运行的命令都是在前台里运行的。
加个& 是在后台运行的,把任务丢到回台区执行
实例:
安装screen命令。安装命令:yum install -y screen
直接敲screen命令,就进入screen虚拟终端了,使用命令W查看
设置一个能够丢到后台的命令,运行一个不能中断的任务,命令:vmstat 1,按ctrl+a+再加d,就丢到后台了
丢到后台的显示
查看丢到后台的命令和任务。
恢复刚刚丢到后台的命令。命令:screen -r 加上id号,
把tty1丢到回台去,并查看。
有时咱们也许会有这样的需求:要执行一个命令或者脚本,可是须要几个小时甚至几天。这就要考虑一个问题,就是中途断网或出现其余意外状况,执行的任务中断了怎么办?你能够把命令或者脚本丢到后台运行,不过也不保险。阿铭下面就介绍两种方法来避免这样的问题发生。
1. 使用nohup
[root@localhost ~]# cat /usr/local/sbin/sleep.sh
#! /bin/bash
sleep 1000
[root@localhost ~]# nohup sh /usr/local/sbin/sleep.sh &
[1] 19997
[root@localhost ~]# nohup: 忽略输入并把输出追加到"nohup.out"
直接加一个 ‘&’ 虽然丢到后台了,可是当退出该终端时颇有可能这个脚本也会退出的,而在前面加上 nohup 就没有问题了,nohup的做用就是不挂断地运行命令。
2. screen工具的使用
简单来讲,screen是一个能够在多个进程之间多路复用一个物理终端的窗口管理器。screen中有会话的概念,用户能够在一个screen会话中建立多个screen窗口,在每个screen窗口中就像操做一个真实的SSH链接窗口那样。下面阿铭介绍screen的一个简单应用。
1)打开一个会话,直接输入screen命令而后回车,进入screen会话窗口。若是你没有screen命令,请用 yum install -y screen 安装。
[root@localhost ~]# screen
[root@localhost ~]#
2)screen -ls 查看已经打开的screen会话
[root@localhost ~]# screen -ls
There is a screen on:
20001.pts-0.localhost (Attached)
1 Socket in /var/run/screen/S-root.
3)Ctrl +a 再按d退出该screen会话,只是退出,并无结束。结束的话输入Ctrl +d 或者输入exit
4)退出后还想再次登陆某个screen会话,使用sreen -r [screen 编号],这个编号就是上例中那个20001。当只有一个screen会话时,后面的编号是能够省略的。当你有某个须要长时间运行的命令或者脚本时就打开一个screen会话,而后运行该任务。按ctrl +a 再按d退出会话,不影响终端窗口上的任何操做
Screen是一款用于命令行终端切换的自由软件。用户能够经过该软件同时链接多个本地或远程的命令行会话,并在其间自由切换。GNU Screen能够看做是窗口管理器的命令行界面版本。它提供了统一的管理多个会话的界面和相应的功能。
会话恢复
只要Screen自己没有终止,在其内部运行的会话均可以恢复。这一点对于远程登陆的用户特别有用——即便网络链接中断,用户也不会失去对已经打开的命令行会话的控制。只要再次登陆到主机上执行screen -r就能够恢复会话的运行。一样在暂时离开的时候,也能够执行分离命令detach,在保证里面的程序正常运行的状况下让Screen挂起(切换到后台)。这一点和图形界面下的VNC很类似。
多窗口
在Screen环境下,全部的会话都独立的运行,并拥有各自的编号、输入、输出和窗口缓存。用户能够经过快捷键在不一样的窗口下切换,并能够自由的重定向各个窗口的输入和输出。Screen实现了基本的文本操做,如复制粘贴等;还提供了相似滚动条的功能,能够查看窗口情况的历史记录。窗口还能够被分区和命名,还能够监视后台窗口的活动。 会话共享 Screen可让一个或多个用户从不一样终端屡次登陆一个会话,并共享会话的全部特性(好比能够看到彻底相同的输出)。它同时提供了窗口访问权限的机制,能够对窗口进行密码保护。
GNU's Screen 官方站点:http://www.gnu.org/software/screen/
语法
# screen [-AmRvx -ls -wipe][-d <做业名称>][-h <行数>][-r <做业名称>][-s ][-S <做业名称>]
选项
-A 将全部的视窗都调整为目前终端机的大小。 -d <做业名称> 将指定的screen做业离线。 -h <行数> 指定视窗的缓冲区行数。 -m 即便目前已在做业中的screen做业,仍强制创建新的screen做业。 -r <做业名称> 恢复离线的screen做业。 -R 先试图恢复离线的做业。若找不到离线的做业,即创建新的screen做业。 -s 指定创建新视窗时,所要执行的shell。 -S <做业名称> 指定screen做业的名称。 -v 显示版本信息。 -x 恢复以前离线的screen做业。 -ls或--list 显示目前全部的screen做业。 -wipe 检查目前全部的screen做业,并删除已经没法使用的screen做业。
经常使用screen参数
screen -S yourname -> 新建一个叫yourname的session screen -ls -> 列出当前全部的session screen -r yourname -> 回到yourname这个session screen -d yourname -> 远程detach某个session screen -d -r yourname -> 结束当前session并回到yourname这个session
在每一个screen session 下,全部命令都以 ctrl+a(C-a) 开始。
C-a ? -> 显示全部键绑定信息 C-a c -> 建立一个新的运行shell的窗口并切换到该窗口 C-a n -> Next,切换到下一个 window C-a p -> Previous,切换到前一个 window C-a 0..9 -> 切换到第 0..9 个 window Ctrl+a [Space] -> 由视窗0循序切换到视窗9 C-a C-a -> 在两个最近使用的 window 间切换 C-a x -> 锁住当前的 window,需用用户密码解锁 C-a d -> detach,暂时离开当前session,将目前的 screen session (可能含有多个 windows) 丢到后台执行,并会回到还没进 screen 时的状态,此时在 screen session 里,每一个 window 内运行的 process (不管是前台/后台)都在继续执行,即便 logout 也不影响。 C-a z -> 把当前session放到后台执行,用 shell 的 fg 命令则可回去。 C-a w -> 显示全部窗口列表 C-a t -> time,显示当前时间,和系统的 load C-a k -> kill window,强行关闭当前的 window C-a [ -> 进入 copy mode,在 copy mode 下能够回滚、搜索、复制就像用使用 vi 同样 C-b Backward,PageUp C-f Forward,PageDown H(大写) High,将光标移至左上角 L Low,将光标移至左下角 0 移到行首 $ 行末 w forward one word,以字为单位往前移 b backward one word,以字为单位日后移 Space 第一次按为标记区起点,第二次按为终点 Esc 结束 copy mode C-a ] -> paste,把刚刚在 copy mode 选定的内容贴上
使用 screen
安装screen
流行的Linux发行版(例如Red Hat Enterprise Linux)一般会自带screen实用程序,若是没有的话,能够从GNU screen的官方网站下载。
[root@TS-DEV ~]# yum install screen [root@TS-DEV ~]# rpm -qa|grep screen screen-4.0.3-4.el5 [root@TS-DEV ~]#
建立一个新的窗口
安装完成后,直接敲命令screen就能够启动它。可是这样启动的screen会话没有名字,实践上推荐为每一个screen会话取一个名字,方便分辨:
[root@TS-DEV ~]# screen -S david
screen启动后,会建立第一个窗口,也就是窗口No. 0,并在其中打开一个系统默认的shell,通常都会是bash。因此你敲入命令screen以后,会马上又返回到命令提示符,仿佛什么也没有发生似的,其实你已经进入Screen的世界了。固然,也能够在screen命令以后加入你喜欢的参数,使之直接打开你指定的程序,例如:
[root@TS-DEV ~]# screen vi david.txt
screen建立一个执行vi david.txt的单窗口会话,退出vi 将退出该窗口/会话。
查看窗口和窗口名称
打开多个窗口后,可使用快捷键C-a w列出当前全部窗口。若是使用文本终端,这个列表会列在屏幕左下角,若是使用X环境下的终端模拟器,这个列表会列在标题栏里。窗口列表的样子通常是这样:
0$ bash 1-$ bash 2*$ bash
这个例子中我开启了三个窗口,其中*号表示当前位于窗口2,-号表示上一次切换窗口时位于窗口1。
Screen默认会为窗口命名为编号和窗口中运行程序名的组合,上面的例子中窗口都是默认名字。练习了上面查看窗口的方法,你可能就但愿各个窗口能够有不一样的名字以方便区分了。可使用快捷键C-a A来为当前窗口重命名,按下快捷键后,Screen会容许你为当前窗口输入新的名字,回车确认。
会话分离与恢复
你能够不中断screen窗口中程序的运行而暂时断开(detach)screen会话,并在随后时间从新链接(attach)该会话,从新控制各窗口中运行的程序。例如,咱们打开一个screen窗口编辑/tmp/david.txt文件:
[root@TS-DEV ~]# screen vi /tmp/david.txt
以后咱们想暂时退出作点别的事情,好比出去散散步,那么在screen窗口键入C-a d,Screen会给出detached提示:
暂时中断会话
半个小时以后回来了,找到该screen会话:
[root@TS-DEV ~]# screen -ls
从新链接会话:
[root@TS-DEV ~]# screen -r 12865
一切都在。
固然,若是你在另外一台机器上没有分离一个Screen会话,就无从恢复会话了。这时可使用下面命令强制将这个会话从它所在的终端分离,转移到新的终端上来:
清除dead 会话
若是因为某种缘由其中一个会话死掉了(例如人为杀掉该会话),这时screen -list会显示该会话为dead状态。使用screen -wipe命令清除该会话:
关闭或杀死窗口
正常状况下,当你退出一个窗口中最后一个程序(一般是bash)后,这个窗口就关闭了。另外一个关闭窗口的方法是使用C-a k,这个快捷键杀死当前的窗口,同时也将杀死这个窗口中正在运行的进程。
若是一个Screen会话中最后一个窗口被关闭了,那么整个Screen会话也就退出了,screen进程会被终止。
除了依次退出/杀死当前Screen会话中全部窗口这种方法以外,还可使用快捷键C-a :,而后输入quit命令退出Screen会话。须要注意的是,这样退出会杀死全部窗口并退出其中运行的全部程序。其实C-a :这个快捷键容许用户直接输入的命令有不少,包括分屏能够输入split等,这也是实现Screen功能的一个途径,不过我的认为仍是快捷键比较方便些。
screen 高级应用
会话共享
还有一种比较好玩的会话恢复,能够实现会话共享。假设你在和朋友在不一样地点以相同用户登陆一台机器,而后你建立一个screen会话,你朋友能够在他的终端上命令:
[root@TS-DEV ~]# screen -x
这个命令会将你朋友的终端Attach到你的Screen会话上,而且你的终端不会被Detach。这样你就能够和朋友共享同一个会话了,若是大家当前又处于同一个窗口,那就至关于坐在同一个显示器前面,你的操做会同步演示给你朋友,你朋友的操做也会同步演示给你。固然,若是大家切换到这个会话的不一样窗口中去,那仍是能够分别进行不一样的操做的。
会话锁定与解锁
Screen容许使用快捷键C-a s锁定会话。锁定之后,再进行任何输入屏幕都不会再有反应了。可是要注意虽然屏幕上看不到反应,但你的输入都会被Screen中的进程接收到。快捷键C-a q能够解锁一个会话。
也可使用C-a x锁定会话,不一样的是这样锁定以后,会话会被Screen所属用户的密码保护,须要输入密码才能继续访问这个会话。
发送命令到screen会话
在Screen会话以外,能够经过screen命令操做一个Screen会话,这也为使用Screen做为脚本程序增长了便利。关于Screen在脚本中的应用超出了入门的范围,这里只看一个例子,体会一下在会话以外对Screen的操做:
[root@TS-DEV ~]# screen -S sandy -X screen ping www.baidu.com
这个命令在一个叫作sandy的screen会话中建立一个新窗口,并在其中运行ping命令。
屏幕分割
如今显示器那么大,将一个屏幕分割成不一样区域显示不一样的Screen窗口显然是个很酷的事情。可使用快捷键C-a S将显示器水平分割,Screen 4.00.03版本之后,也支持垂直分屏,快捷键是C-a |。分屏之后,可使用C-a <tab>在各个区块间切换,每一区块上均可以建立窗口并在其中运行进程。
能够用C-a X快捷键关闭当前焦点所在的屏幕区块,也能够用C-a Q关闭除当前区块以外其余的全部区块。关闭的区块中的窗口并不会关闭,还能够经过窗口切换找到它。
C/P模式和操做
screen的另外一个很强大的功能就是能够在不一样窗口之间进行复制粘贴了。使用快捷键C-a <Esc>或者C-a [能够进入copy/paste模式,这个模式下能够像在vi中同样移动光标,并可使用空格键设置标记。其实在这个模式下有不少相似vi的操做,譬如使用/进行搜索,使用y快速标记一行,使用w快速标记一个单词等。关于C/P模式下的高级操做,其文档的这一部分有比较详细的说明。
通常状况下,能够移动光标到指定位置,按下空格设置一个开头标记,而后移动光标到结尾位置,按下空格设置第二个标记,同时会将两个标记之间的部分储存在copy/paste buffer中,并退出copy/paste模式。在正常模式下,可使用快捷键C-a ]将储存在buffer中的内容粘贴到当前窗口。
更多screen功能
同大多数UNIX程序同样,GNU Screen提供了丰富强大的定制功能。你能够在Screen的默认两级配置文件/etc/screenrc和$HOME/.screenrc中指定更多,例如设定screen选项,定制绑定键,设定screen会话自启动窗口,启用多用户模式,定制用户访问权限控制等等。若是你愿意的话,也能够本身指定screen配置文件。
以多用户功能为例,screen默认是以单用户模式运行的,你须要在配置文件中指定multiuser on 来打开多用户模式,经过acl*(acladd,acldel,aclchg...)命令,你能够灵活配置其余用户访问你的screen会话。更多配置文件内容请参考screen的man页。