shell脚本自动化安装启动各种服务

1、自动化配置dns服务器

 A主机:vim dns.sh #!/bin/bash# 自动化部署dns# 1、下载bind# 2、修改配置文件# vim /etc/named.conf # listen-on port 53 { 127.0.0.1;any; };   修改(定位替换)# allow-query     { localhost;any; };     修改(定位替换)# vim /etc/named.rfc1912.zones  (最后追加)# zone "baibai.com" IN {#        type master;#        file "baibai.com.zone";#        allow-update { none; };#};# 3、创建zone文件# cd /var/named/# cp -p named.localhost baibai.com.zone# 4、修改zone文件# vim baibai.com.zone # www     A       10.0.0.100      (最后追加)# 5、重启服务# systemctl restart namedyum -y install bindsed -i '/listen-on/ s/127.0.0.1;/127.0.0.1;any;/' /etc/named.confsed -i '/allow-query/ s/localhost;/localhost;any;/' /etc/named.confsed -i '$a zone "a.com" IN {' /etc/named.rfc1912.zonessed -i '$a        type master;' /etc/named.rfc1912.zonessed -i '$a        file "a.com.zone";' /etc/named.rfc1912.zonessed -i '$a        allow-update { none; };' /etc/named.rfc1912.zonessed -i '$a };' /etc/named.rfc1912.zonescd /var/named/cp -p named.localhost a.com.zonesed -i '$a www     A       10.0.0.100'   /var/named/a.com.zonesystemctl restart namedsh dns.shB主机:vim dnscs.sh #!/bin/bash#测试机测试dnsyum -y install bind-utilsecho "nameserevr 10.0.0.12" > /etc/resolv.confnslookup www.a.comsh dnscs.sh

2、自动化配置rsync服务

 A主机:ssh-keygen ssh-copy-id vim rsync.sh#!/bin/bash# 自动化部署rsync# 先自己做免密# 1、下载rsync和inotify-tools软件  yum -y install rsync inotify-tools# 2、创建共享目录与共享文件   mkdir rsync   touch rsync/file{0..4}# 3、修改配置文件 vim /etc/rsyncd.conf  (最后面追加)# [app]# path=/root/rsync/     //项目路径# log file=/var/log/rsync.log   //项目日志文件路径# 4、重启rsync服务   systemctl restart rsyncd# 5、写一个监控脚本   先创建一个文件  touch inotify.sh  vim inotify.sh  (直接最后追加插入)# #!/bin/bash# /usr/bin/inotifywait -mrq -e modify,delete,create,attrib,move /root/rsync | while read events# do#    rsync -av --delete /root/rsync root@10.0.0.20:/tmp/#    echo "`date +%F\ %T`出现事件$events" >> /var/log/rsync.log 2>&1# done# 6、为脚本添加执行权限   chmod +x inotify.sh # 7、执行监控脚本并放入后台  nohup ./inotify.sh &yum -y install rsyncyum -y install inotify-toolsmkdir rsynctouch rsync/file{0..4}sed -i '$a [app]' /etc/rsyncd.confsed -i '$a path=/root/rsync/' /etc/rsyncd.confsed -i '$a log file=/var/log/rsync.log'  /etc/rsyncd.confsystemctl restart rsyncdtouch inotify.shecho "#" > /root/inotify.shsed -i '$a #!/bin/bash' /root/inotify.shsed -i '$a /usr/bin/inotifywait -mrq -e modify,delete,create,attrib,move /root/rsync | while read  events' /root/inotify.shsed -i '$a do' /root/inotify.shsed -i '$a rsync -av --delete /root/rsync root@10.0.0.11:/tmp/' /root/inotify.shsed -i '$a done'sed -i '1d' /root/inotify.shchmod +x inotify.shnohup ./inotify.sh &sh rsync.shB主机:测试机测试rm -rf /tmp/*ls /tmp/A主机:touch /root/rsync/file5B主机:测试机测试ls /tmp/

3、自动化配置FTP服务

 A主机:vim ftp.sh#!/bin/bash# 1、下载vsftpd软件包   yum -y install vsftpd# 2、开启vsftpd服务    systemctl start vsftpd# 3、修改vsftpd配置文件    vim /etc/vsftpd/vsftpd.conf   (查找修改)# anonymous_enable=NO       //不允许匿名访问# local_root=/data/kehu       //指定用户存放文件的路径# chroot_local_user=YES       //限定目录# chroot_list_enable=YES    //开启用户列表文件# chroot_list_file=/etc/vsftpd/chroot_list    //指定用户列表文件# 4、重启vsftpd服务     systemctl restart vsftpd# 5、创建用户    useradd kehu# 6、设置用户密码    echo kehu | passwd --stdin kehu# 7、创建存放目录    mkdir -p /data/kehu/# 8、为用户赋予所有权限    setfacl -R -m u:kehu:rwx /data/kehu/# 9、将用户放入用户列表文件中,表示不被禁锢    echo kehu >> /etc/vsftpd/chroot_listyum -y install vsftpdsystemctl start vsftpdsed -i '/anonymous_enable/ s/YES/NO/' /etc/vsftpd/vsftpd.confsed -i '/anonymous_enable/ a local_root=/data/kehu' /etc/vsftpd/vsftpd.confsed -i '/chroot_local_user=YES/ s/#//' /etc/vsftpd/vsftpd.confsed -i '/chroot_list_enable=YES/ s/#//' /etc/vsftpd/vsftpd.confsed -i '/chroot_list_file/ s/#//' /etc/vsftpd/vsftpd.confuseradd kehuecho kehu | passwd --stdin kehumkdir -p /data/kehu/setfacl -R -m u:kehu:rwx /data/kehu/echo kehu >> /etc/vsftpd/chroot_listsystemctl restart vsftpdsh ftp.shB主机:测试机测试yum -y install ftpftp 10.0.0.10kehukehu

4、自动化配置frp的服务器端与客户端

 A主机:vim frp.sh#!/bin/bash# 1、确保本机中有软件包  frp_0.33.0_linux_amd64.tar.gz# 2、解压软件包 tar -zxvf frp_0.33.0_linux_amd64.tar.gz# 3、切换到解压后的目录中   cd frp_0.33.0_linux_amd64/# 4、修改配置文件   vim frps.ini   (全部追加)# dashboard_user=aaa# dashboard_pwd=aaa# dashboard_port=7500# 5、启动frp服务    ./frps -c frps.ini  tar -zxf frp_0.33.0_linux_amd64.tar.gzcd frp_0.33.0_linux_amd64/sed -i '$a dashboard_user=aaa' frps.inised -i '$a dashboard_pwd=aaa' frps.inised -i '$a dashboard_port=7500' frps.ini./frps -c frps.inish frp.shB主机:vim frpcs.sh#!/bin/bash# 测试机测试frp服务器# 1、解压软件包# 2、切换到目录中# 3、修改配置文件  vim frpc.ini# [common]# server_addr = 10.0.0.20# server_port = 7000# [lijiaqi]# type = tcp# local_ip = 127.0.0.1# local_port = 22# remote_port = 6064# 4、启动frp客户端服务 ./frpc -c frpc.initar -zxf frp_0.33.0_linux_amd64.tar.gzcd frp_0.33.0_linux_amd64sed -i '/server_addr/ s/127.0.0.1/10.0.0.10/' frpc.inised -i '/[ssh]/ s/ssh/baibai/' frpc.inised -i '/remote_port/ s/6000/6035/' frpc.ini./frpc -c frpc.inish frpcs.sh

5、自动化配置samba共享

 A主机:vim samba.sh#!/bin/bash# 自动化配置samba共享# 1、下载samba软件   yum -y install samba# 2、修改samba配置文件  vim /etc/samba/smb.conf   (直接最后追加)# [smb_share]     //这是共享的名称,客户端在访问时会看到这个名称。#     comment = samba service    //这是对该共享的注释说明,用于提供一些描述信息,这里说明是“Samba 服务”#     path = /samba         //指定了实际共享的目录路径为`/bakpu`#     guest ok = no         //表示不允许访客访问,只有经过授权的用户才能访问#     writable = yes        //表示允许对该共享目录进行写入操作# 3、创建共享目录   mkdir  /samba# 4、添加samba用户    useradd user01# 5、为用户设置密码   smbpasswd -a user01# 6、为用户赋予所有权限   setfacl -m u:user01:rwx /bakpu/*# 7、启动nmb服务  systemctl start nmb.service# 8、启动smb服务   systemctl start smb.service yum -y install sambased -i '$a [smb_share]' /etc/samba/smb.confsed -i '$a comment = samba service' /etc/samba/smb.confsed -i '$a path = /samba' /etc/samba/smb.confsed -i '$a guest ok = no' /etc/samba/smb.confsed -i '$a writable = yes' /etc/samba/smb.confmkdir /sambauseradd user01echo "现在请您输入你想要设置的账户密码:"smbpasswd -a user01setfacl -m u:user01:rwx /samba/systemctl start nmb.servicesystemctl start smb.serviceB主机:测试机测试1、直接windows测试(直接映射)2、linux主机测试yum -y install samba-clientsmbclient //10.0.0.10/smb_share -U user01

6、自动化配置yum仓库初始化(包括阿里云和epel)

 A主机:vim yum.sh#!/bin/bash# 自动化配置yum仓库初始化(包括阿里云和epel)# 1、搭建本地仓库 # tar -cf /etc/yum.repos.d/yum.repo.tar /etc/yum.repos.d/*# rm -rf /etc/yum.repos.d/*# vim /etc/yum.repos.d/hh.repo# [hh]# name=hh# baseurl=file:///mnt# gpgcheck=0# enable=1# mount /dev/cdrom /mnt# 2、下载wget软件  yum -y install wget# 3、在阿里云官网wget下载阿里云镜像 wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo# 4、下载epel,创建epel仓库   yum -y install epel-release.noarch# 5、清除缓存  yum clean all  创建缓存 yum makecachetar -cf /etc/yum.repos.d/yum.repo.tar /etc/yum.repos.d/*rm -rf /etc/yum.repos.d/*echo "#" > /etc/yum.repos.d/hh.reposed -i '$a [hh]' /etc/yum.repos.d/hh.repo               sed -i '$a name=hh' /etc/yum.repos.d/hh.reposed -i '$a baseurl=file:///mnt' /etc/yum.repos.d/hh.repo               sed -i '$a gpgcheck=0' /etc/yum.repos.d/hh.repo               sed -i '$a enable=1' /etc/yum.repos.d/hh.repo               sed -i '1d' /etc/yum.repos.d/hh.repoyum -y install wgetwget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repoyum -y install epel-release.noarchyum clean allyum makecache

7、自动化配置nfs服务

 A主机:vim nfs.sh#!/bin/bash# 自动化配置nfs服务# 1、下载nfs软件与依赖软件 yum -y install nfs-utils.x86_64 rpcbind.x86_64# 2、创建共享目录  mkdir /nfsshare# 3、编辑配置文件指定要暴露的目录  vim /etc/exports (这是个新文件,直接追加最后)# /nfsshare   *(rw,sync)yum -y install nfs-utils.x86_64 rpcbind.x86_64mkdir /nfsshareecho "#" > /etc/exportssed -i '$a /nfsshare  *(rw,sync)' /etc/exportssed -i '1d' /etc/exportssystemctl start nfs-serversh nfs.shB主机:测试机测试yum -y install nfs-utils.x86_64mkdir /nfsmount -t nfs 10.0.0.10:/nfsshare /nfsls /nfs

8、自动化配置ntp服务

 A主机:vim ntp.sh #!/bin/bash# 自动化配置ntp服务# 1、下载ntp软件    yum -y install ntp.x86_64# 2、修改ntp配置文件   vim /etc/ntp.conf# 15行加入   restrict 10.0.0.0 mask 255.255.255.0   //允许10.0.0.0网段的主机访问# 3、与官方时间服务器同步时间  ntpdate cn.ntp.org.cn# 4、启动ntp服务  systemctl start ntpd# 5、编辑计划任务定时同步时间  crontab -e # * 4 * * * /usr/sbin/ntpdate cn.ntp.org.cnyum -y install ntp.x86_64sed -i '/restrict ::1/a restrict 10.0.0.0 mask 255.255.255.0' /etc/ntp.confntpdate cn.ntp.org.cnsystemctl start ntpdecho "您现在可以编辑一个定时任务用于定时向官方时间服务器同步时间,以防止您当前的时间服务器时间错误"echo "你可以输入以下命令来编辑一个定时任务"echo "1、crontab -e"echo "2、* 4 * * * /usr/sbin/ntpdate cn.ntp.org.cn"echo "该命令为每到4点时就进行一次时间同步"sh ntp.shB主机:测试机测试datedate -s "2014-07-28 00:00"ntpdate 10.0.0.10date

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/50219.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vector以及迭代器失效

前言 学习完string,之后学习的就是vector。vector就是之前C语言中讲到过的顺序表,用三个变量分别记录资源的位置,容器的容量和容器中元素个数。原来的写法是直接使用指针加两个int变量,而标准库中,三个都是由指针确定的…

sql server 连接报错error 40

做个简单的记录,造成40 的原因有很多,你的错误并不一定就是我遇到的这种情况. 错误描述: 首先我在使用ssms 工具连接的时候是可以正常连接的,也能对数据库进行操作. 在使用 ef core 连接 Sql Server 时报错: Microsoft.Data.SqlClient.SqlException (0x80131904): A network-r…

hadoop学习(二)

一.MapReduce 1.1定义:是一个分布式运算程序的编程框架 1.2核心功能:将用户编写的业务逻辑代码和自带默认组件整合成一个完整的分布式运算程序,并发运行在一个Hadoop集群上。 1.3优点 1)易于编程 它简单的实现一些接口&#…

【Linux】Ubuntu解决Release 文件已经过期问题

​今天在执行update更新软件包时遇到了此问题:E: http://cn.archive.ubuntu.com/ubuntu/dists/jammy-updates/InRelease 的 Release 文件已经过期(已经过期了 247天 21小时 33分 15秒)。该仓库的更新将不会应用,如图 ​ 这个报错之前其实经常遇到&#x…

电脑虚拟摄像头软件分享|用手机打破电脑摄像头的极限

随着手机摄像头的不断更新迭代,手机已经接近专业电脑摄像头的画质。这让我们可以花费更低的成本获取优质的电脑录像画面。今天小编给大家详细讲解电脑虚拟摄像头的在我们日常生活中的妙用,以及分享几款口碑不错的电脑虚拟摄像头软件。有需要的小伙伴可以…

周末两天我搭建了一个智能问答ai工具网站

背景 周五的时候我去看了一下Boos 直聘,然后沟通了一个10k-15k的职位,她问我会不会后端,我说会一些node,然后他跟我说他们的工作是去对接第三方的的AI工具,我说这个没问题,我自己原来接触过Stable Diffusi…

智能识海:基于深度学习的海洋生物检测系统开发指南

基于深度学习的海洋动物检测系统(UI界面YOLOv8/v7/v6/v5代码训练数据集) 引言 海洋动物检测在海洋生态保护、科学研究和渔业管理中起着至关重要的作用。通过深度学习技术,尤其是YOLO(You Only Look Once)模型&#x…

算法训练营第47天|1143.最长公共子序列|1035.不相交的线|53. 最大子序和|392.判断子序列

1143.最长公共子序列 思路:这道题比较难理解的是递推公式,要想明白状态转换和各个状态的意义。 如果text1[i - 1] 与 text2[j - 1]相同,那么找到了一个公共元素,所以dp[i][j] dp[i - 1][j - 1] 1; 如果text1[i - 1] 与 text2[j…

IO的分类有哪些

目录 一:BIO,NIO,AIO有什么区别 二:BIO,NIO,AIO有哪些适用场景 三:BIO的编程流程 四:NIO的三大核心部分 五:NIO中buffer的属性有哪些 六:BIO与NIO的对比 七:简…

Unity3D 转换微信小游戏指引 05 广告内购

Unity3D 转换微信小游戏指引系列(第五期 完结) 广告 在小程序后台页面找到推广->流量主 开通条件如下: 开通之后,需要接入广告组件。 调用创建广告组件的接口时,需要传入参数 adUnitId,这个是开通流量…

「C++系列」数组

文章目录 一、数组1. 声明数组2. 初始化数组3. 访问数组元素4. 遍历数组注意事项示例代码 二、多维数组1. 声明二维数组2. 初始化二维数组3. 访问二维数组元素4. 遍历二维数组注意事项示例代码 三、指向数组的指针1. 声明指向数组的指针2. 通过指针访问数组元素3. 指针和数组的…

json的数据结构

JSON 的数据结构 JSON 由两种数据结构组成:对象(字典)和数组。 一、对象 对象(object)是由键值对组成的无序集合。 键是字符串,值可以是任何类型,包括对象和数组;对象由一对花括…

Android 10.0 framework默认沉浸式状态栏功能实现

1. 前言 在10.0的系统rom定制化开发中,在实现状态栏的某些定制化开发中,在某些产品需要实现沉浸式状态栏,就是需要app 能全屏显示同样也能显示状态栏,接下来就来分析下相关的功能实现 如图: 2.framework默认沉浸式状态栏功能实现的核心类 frameworks\base\core\java\andro…

【神经网络】梯度下降的优化方法【数学公式+代码示例】

文章目录 1、简介2、指数加权平均2.1、公式2.2、代码 3、Momentum⭐3.1、公式演变3.2、代码 4、AdaGrad4.1、计算步骤4.2、代码示例 5、RMSProp5.1、公式5.2、代码5.3、小结 6、Adam6.1、公式和步骤解释⭐6.2、代码⭐6.3、优点 7、何为鞍点8、小结 🍃作者介绍&#…

Vue 渲染函数 JSX

Vue 提供一个h()函数用于创建vnodes,用于渲染网页。 JSX是JS的一个类似XML的扩展,与h()函数类似,也是可以创建vnodes,用于渲染网页。 1 渲染函数 & JSX 1.1 渲染函数 组合式API,setup()钩子的返回值是用于暴露数据给模版,…

国防科技大学深圳地区新生欢送会圆满举行

2024年7月28日,第97个八一建军节来临之际,在这个充满希望的盛夏时节,深圳地区迎来了13名即将踏入国防科技大学的优秀学子。 为了庆祝这一荣耀时刻,并表达对新生的深切祝福,在国防科技大学深圳校友会黄丹会长的积极倡议…

书生大模型实战营--L1关卡-Llamaindex RAG实践

一、安装llamaindex库 pip install llama-index pip install llama-index-embeddings-huggingface 二、问2024年巴黎奥运会 中国队获得几枚金牌,无法回答该问题 三、构建Llamaindex RAG 1、初始化llm 2、构建词向量模型 下载模型:git clone https://…

基于k8s快速搭建docker镜像服务的demo

基于k8s快速搭建docker镜像服务的demo 一、环境准备 如标题,你需要环境中有和2个平台,并且服务器上也已经安装好docker服务 接下来我来构建一个docker镜像,然后使用harbork8s来快速部署服务demo 二、部署概述 使用docker构建镜像&#x…

【学习笔记】Redis学习笔记——第17章 集群

第17章 集群 17.1 节点 使用cluster meet命令将其他节点添加到当前节点集群中 17.1.1 启动节点 通过cluster-enabled设置来决定是否启用集群 17.1.2 集群数据结构 每个节点都保存了自己及其他节点的IP端口号等信息 17.1.3 cluster meet命令的实现 是收到命令的节点和新…

flatpak vscode

解决集成终端无法使用主机命令和字体的问题 Shift Ctrl P:搜索user set,点击带JSON的,把这些加进去 {"terminal.integrated.defaultProfile.linux": "bash","terminal.integrated.profiles.linux": {"…