1. 程式人生 > >linux基礎nfs服務和計劃任務crond服務

linux基礎nfs服務和計劃任務crond服務

tom 客戶端連接 表示 install secure access 開機啟動 系統 分鐘

一.nfs服務

1.安裝:yum install rpcbind nfs-utils -y

2.配置:NFS服務的配置文件為 /etc/exports,這個文件是NFS的主要配置文件,不過系統並沒有默認值,所以這個文件不一定會存在,可能要使用vim手動建立,然後在文件裏面寫入配置內容。

/etc/exports文件內容格式:

<輸出目錄> [客戶端1 選項(訪問權限,用戶映射,其他)] [客戶端2 選項(訪問權限,用戶映射,其他)]

a. 輸出目錄:

輸出目錄是指NFS系統中需要共享給客戶機使用的目錄;

b. 客戶端:

客戶端是指網絡中可以訪問這個NFS輸出目錄的計算機

客戶端常用的指定方式

      • 指定ip地址的主機:192.168.0.200
      • 指定子網中的所有主機:192.168.0.0/24 192.168.0.0/255.255.255.0
      • 指定域名的主機:david.bsmart.cn
      • 指定域中的所有主機:*.bsmart.cn
      • 所有主機:*

c. 選項:

選項用來設置輸出目錄的訪問權限、用戶映射等。

NFS主要有3類選項:

訪問權限選項

      • 設置輸出目錄只讀:ro
      • 設置輸出目錄讀寫:rw

用戶映射選項

      • all_squash:將遠程訪問的所有普通用戶及所屬組都映射為匿名用戶或用戶組(nfsnobody);
      • no_all_squash:與all_squash取反(默認設置);
      • root_squash:將root用戶及所屬組都映射為匿名用戶或用戶組(默認設置);
      • no_root_squash:與rootsquash取反;
      • anonuid=xxx:將遠程訪問的所有用戶都映射為匿名用戶,並指定該用戶為本地用戶(UID=xxx);
      • anongid=xxx:將遠程訪問的所有用戶組都映射為匿名用戶組賬戶,並指定該匿名用戶組賬戶為本地用戶組賬戶(GID=xxx);

其它選項

      • secure:限制客戶端只能從小於1024的tcp/ip端口連接nfs服務器(默認設置);
      • insecure:允許客戶端從大於1024的tcp/ip端口連接服務器;
      • sync:將數據同步寫入內存緩沖區與磁盤中,效率低,但可以保證數據的一致性;
      • async:將數據先保存在內存緩沖區中,必要時才寫入磁盤;
      • wdelay:檢查是否有相關的寫操作,如果有則將這些寫操作一起執行,這樣可以提高效率(默認設置);
      • no_wdelay:若有寫操作則立即執行,應與sync配合使用;
      • subtree:若輸出目錄是一個子目錄,則nfs服務器將檢查其父目錄的權限(默認設置);

no_subtree:即使輸出目錄是一個子目錄,nfs服務器也不檢查其父目錄的權限,這樣可以提高效率;

修改配置

[[email protected] nginx]# cat /etc/exports
/share 192.168.31.0/24(rw,sync,fsid=0)

開權限(nfs開啟了w權限還不行,others還需要對/share目錄有w權限)

chmod -R o+w /share

先為rpcbind和nfs做開機啟動:

[[email protected] nginx]# systemctl enable nfs-server.service
[[email protected] nginx]# systemctl enable rpcbind.service

啟動(必須先啟動rpcbind服務)

[[email protected] nginx]# systemctl start rpcbind.service
[[email protected] nginx]# systemctl start nfs-server.service

確認nfs服務器啟動成功

[[email protected] nginx]# rpcinfo
[[email protected] nginx]# exportfs
/share 192.168.31.0/24

[[email protected] nginx]# showmount -e #默認查看自己共享的服務,前提是要DNS能解析自己,不然容易報錯
Export list for MiWiFi-R3-srv:
/share 192.168.31.0/24

[[email protected] nginx]# showmount -a #顯示已經與客戶端連接上的目錄信息
All mount points on MiWiFi-R3-srv:

=====================客戶端

yum install rpcbind nfs-utils -y

systemctl enable rpcbind.service && systemctl start rpcbind.service

showmount -e NFS服務器IP #檢查 NFS 服務器端是否有目錄共享
mount -t nfs 192.168.31.106:/share /var/www/html/

=====================測試
基於nginx的負載均衡配置,打開後端被代理服務的access.log日誌,tail -f access.log來觀察訪問,訪問LB刷新頁面發現內容保持一致,但是每臺被代理的機器的access.log日誌都有新的內容進來

二.計劃任務crond服務

什麽是計劃任務:
後臺運行,到了預定的時間就會自動執行的任務,前提是:事先手動將計劃任務設定好。這就用到了crond服務

crond服務相關的軟件包
[[email protected] ~]# rpm -qa |grep cron
cronie-anacron-1.4.11-14.el7.x86_64
crontabs-1.11-6.20121102git.el7.noarch
cronie-1.4.11-14.el7.x86_64

這些包在最小化安裝系統時就已經安裝了,並且會開機自啟動crond服務,並為我們提供好編寫計劃任務的crontab命令。

計劃任務分為兩類:系統級和用戶級

首先需要知道的是,無論是系統級還是用戶級的cron計劃都是文本文件,系 統的計劃文件存放在/etc/crontab路徑下。用戶的計劃文件放在/var/spool/cron/用戶名,不管是哪一種,都可以滿足我們定制計劃任務的需求。

root用戶可以直接對文件進行修改來編寫計劃任務也可以使用 crontab -e命令,而普通用戶只能使用後者。除此之外,系統crontab文件中任務的定義也有所不同,在前五個部分之後插入了一個“用戶”部分。

[[email protected] ~]# cat /etc/crontab #查看全局計劃任務
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
* * * * * root run-parts /test #run-parts命令,可以執行一個目錄下所有的可執行文件,目錄下文件必須有執行權限

You have new mail in /var/spool/mail/root


[[email protected] ~]# crontab -u tom -l #通過命令查看用戶tom的計劃任務
*/1 * * * * echo 123213123213


[[email protected] ~]# cat /var/spool/cron/tom #從文件中查看用戶tom的計劃任務
*/1 * * * * echo 123213123213

crontab命令編寫計劃任務

語  法:crontab [-u <用戶名稱>][配置文件] 或 crontab [-u <用戶名稱>][-elr]

crontab任務配置基本格式:
* *  *  *  *  command
分鐘(0-59) 小時(0-23) 日期(1-31) 月份(1-12) 星期(0-6,0代表星期天)  命令

第1列表示分鐘1~59 每分鐘用*或者 */1表示
第2列表示小時1~23(0表示0點)
第3列表示日期1~31
第4列表示月份1~12
第5列標識號星期0~6(0表示星期天)
第6列要運行的命令

參  數:
-e  編輯該用戶的計時器設置。
-l  列出該用戶的計時器設置。
-r  刪除該用戶的計時器設置。
-u<用戶名稱>  指定要設定計時器的用戶名稱。

註意:

1 查看計劃任務的執行:tail -f /var/log/cron

2 寫計劃任務時,命令必須加上絕對路徑,否則會出現這種情況:從日誌中看,確實觸發了計劃任務的執行,但是命令卻沒有執行成功,比如* * * * * reboot就會出現這種情況,需要將reboot寫成/usr/sbin/reboot

crontab例子:

30 21 * * * /usr/local/etc/rc.d/apache restart #每晚的21:30 重啟apache

45 4 1,10,22 * * /usr/local/etc/rc.d/apache restart #每月1、10、22日的4 : 45重啟apache

10 1 * * 6,0 /usr/local/etc/rc.d/apache restart #每周六、周日的1 : 10重啟apache

0,30 18-23 * * * /usr/local/etc/rc.d/apache restart #每天18 : 00至23 : 00之間每隔30分鐘重啟apache

0 23 * * 6 /usr/local/etc/rc.d/apache restart #每星期六的11 : 00 pm重啟apache

* 23-7/1 * * * /usr/local/etc/rc.d/apache restart #晚上11點到早上7點之間,每隔一個小時的每分鐘重啟 apache

0 */1 * * * /usr/local/etc/rc.d/apache restart #每一小時重啟apache

linux基礎nfs服務和計劃任務crond服務