首页 > 系统相关 >Smartkit安装Ubuntu OS系统后,执行脚本批量配置网络和更新软件

Smartkit安装Ubuntu OS系统后,执行脚本批量配置网络和更新软件

时间:2023-09-04 18:46:56浏览次数:49  
标签:generic Smartkit apt echo etc file Ubuntu root OS

#!/bin/bash
#---------------------
# system init config
#---------------------

# enable root login
sed -i.bak '31 a\PermitRootLogin yes' /etc/ssh/sshd_config
/etc/init.d/ssh restart


# enable offline huaweicloud sources.list
cat>/etc/apt/sources.list<<EOF
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal main restricted
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal-updates main restricted
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal universe
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal-updates universe
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal multiverse
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal-updates multiverse
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal-backports main restricted universe multiverse
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal-security main restricted
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal-security universe
deb http://168.7.10.14/mirror/repo.huaweicloud.com/ubuntu-ports/ focal-security multiverse
EOF


cat>/root/iplist.csv<<EOF
#SN..................ctl_nic....ctl_ip...ctl_vlan...bondname...nic01_name..nic02_name..bond_mode...bond_ip...gw_ip...dns_ip
2102312PRN10L1000352,enp133s0,168.31.0.14/24,10,bond4,enp131s0,enp132s0,802.3ad,168.17.0.2/24,168.17.0.1,127.0.0.1,0
2102312PRN10L1000361,enp133s0,168.31.0.15/24,10,bond4,enp131s0,enp132s0,802.3ad,168.17.0.3/24,168.17.0.1,127.0.0.1,0
2102312PRN10L1000358,enp133s0,168.31.0.16/24,10,bond4,enp131s0,enp132s0,802.3ad,168.17.0.4/24,168.17.0.1,127.0.0.1,0
2102312PRN10L1000357,enp133s0,168.31.0.17/24,10,bond4,enp131s0,enp132s0,802.3ad,168.17.0.5/24,168.17.0.1,127.0.0.1,0
2102312PRN10L1000354,enp133s0,168.31.0.18/24,10,bond4,enp131s0,enp132s0,802.3ad,168.17.0.6/24,168.17.0.1,127.0.0.1,0
EOF

sleep 3

sn=$(dmidecode -t system|grep -i serial|awk '{print $3}')
ips=$(cat /root/iplist.csv|grep -i $sn)
ctl_nic=$(echo $ips|awk -F"," '{print $2}')
ctl_ip=$(echo $ips|awk -F"," '{print $3}')
ctl_vlan=$(echo $ips|awk -F"," '{print $4}')

bondname=$(echo $ips| awk -F"," '{print $5}')
nic01_name=$(echo $ips|awk -F "," '{print $6}')
nic02_name=$(echo $ips|awk -F "," '{print $7}')
bond_mode=$(echo $ips| awk -F"," '{print $8}')
bond_ip=$(echo $ips|awk -F "," '{print $9}')
gw_ip=$(echo $ips|awk -F "," '{print $10}')
dns_ip=$(echo $ips|awk -F "," '{print $11}')

#---------------------------------------------------------
rm -rf /etc/netplan/*.yaml
cat>/etc/netplan/$bondname.yaml<<EOF
network:
  ethernets:
    $nic01_name:
      addresses: []
      dhcp4: true
      dhcp6: true
    $nic02_name:
      addresses: []
      dhcp4: true
      dhcp6: true
  bonds:
    $bondname:
      addresses: [ $bond_ip ]
      gateway4: $gw_ip
      nameservers:
        addresses: [ $dns_ip ]
      interfaces:
      - $nic01_name
      - $nic02_name
      parameters:
        lacp-rate: fast
        mode: $bond_mode
        transmit-hash-policy: layer2
EOF

cat>/etc/netplan/mgmt-storage.yaml<<EOF
network:
  version: 2
  ethernets:
      $ctl_nic:
          dhcp4: no
  vlans:
      ${ctl_nic}.vlan${ctl_vlan}:
          id: $ctl_vlan
          link: ${ctl_nic}
          addresses: ["${ctl_ip}"]
          nameservers:
            addresses: [ 8.8.8.8,127.0.0.1 ]
EOF

netplan apply

# config hostname mapping
cat>/etc/hosts<<EOF
168.17.0.2 master01
168.17.0.3 master02
168.17.0.4 agent01
168.17.0.5 agent02
168.17.0.6 agent03
EOF

cat>/root/init.sh<<EOF
cat>>/etc/security/limits.conf<<EOFB
* soft memlock unlimited
* hard memlock unlimited
* soft stack unlimited
* hard stack unlimited
* soft nofile 1000000
* hard nofile 1000000
* hard nproc 1000000
* soft nproc 1000000
EOFB
EOF


# DonauScheduler User and group
groupadd -g 60001 donau_guest
useradd -g 60001 -m -u 60001 -s /bin/bash donau_guest
echo "donau_guest:huawei@123" | chpasswd 

groupadd -g 60002 ccs_master
useradd -g 60002 -m -u 60002 -s /bin/bash ccs_master
echo "ccs_master:huawei@123" | chpasswd 

groupadd -g 60003 ccs_agent
useradd -g 60003 -m -u 60003 -s /bin/bash ccs_agent
echo "ccs_agent:huawei@123" | chpasswd 

groupadd -g 60004 ccs_auth
useradd -g 60004 -m -u 60004 -s /bin/bash ccs_auth
echo "ccs_auth:huawei@123" | chpasswd 

groupadd -g 60005 ccs_ignite
useradd -g 60005 -m -u 60005 -s /bin/bash ccs_ignite
echo "ccs_ignite:huawei@123" | chpasswd 

groupadd -g 60006 ccs_cli
useradd -g 60006 -m -u 60006 -s /bin/bash ccs_cli
echo "ccs_cli:huawei@123" | chpasswd 

groupadd -g 60007 postgres
useradd -g 60007 -m -u 60007 -s /bin/bash postgres
echo "postgres:huawei@123" | chpasswd 

groupadd -g 60008 ccs_etcd
useradd -g 60008 -m -u 60008 -s /bin/bash ccs_etcd
echo "ccs_etcd:huawei@123" | chpasswd 

# DonauPortal User and group
groupadd -g 60009 ccp_sysadmin
useradd -g 60009 -m -u 60009 -s /bin/bash ccp_sysadmin
echo "ccp_sysadmin:huawei@123" | chpasswd 

groupadd -g 60010 ccp_audadmin
useradd -g 60010 -m -u 60010 -s /bin/bash ccp_audadmin
echo "ccp_audadmin:huawei@123" | chpasswd 

groupadd -g 60013 ccp_secadmin
useradd -g 60013 -m -u 60013 -s /bin/bash ccp_secadmin
echo "ccp_secadmin:huawei@123" | chpasswd 

useradd -g 60002 -m -u 60011 -s /bin/bash ccp_master
echo "ccp_master:huawei@123" | chpasswd 


share_dir=workspace

mkdir -p /${share_dir}/donau
chown root:root /${share_dir}/donau
chmod 755 /${share_dir}/donau -R

mkdir -p /${share_dir}/license
chown ccs_master:ccs_master /${share_dir}/license
chmod 770 /${share_dir}/license -R

mkdir -p /${share_dir}/data
chown ccs_master:ccs_master /${share_dir}/data
chmod 750 /${share_dir}/data -R

mkdir -p /${share_dir}/dataupload
chown ccp_master:root /${share_dir}/dataupload
chmod 700 /${share_dir}/dataupload -R

mkdir -p /${share_dir}/jobdata
chown root:root /${share_dir}/jobdata
chmod 755 /${share_dir}/jobdata -R

mkdir -p /${share_dir}/portal_data
chown root:root /${share_dir}/portal_data
chmod 755 /${share_dir}/portal_data -R

mkdir -p /${share_dir}/scheduler_db
chown root:root /${share_dir}/scheduler_db
chmod 755 /${share_dir}/scheduler_db -R

mkdir -p /${share_dir}/portal_db
chown root:root /${share_dir}/portal_db
chmod 755 /${share_dir}/portal_db -R

mkdir -p /${share_dir}/backup
chown root:root /${share_dir}/backup
chmod 755 /${share_dir}/backup -R

mkdir -p /${share_dir}/scheduler_agent
chown root:root /${share_dir}/scheduler_agent
chmod 755 /${share_dir}/scheduler_agent -R

mkdir -p /${share_dir}/storage
chown ccp_master:root /${share_dir}/storage
chmod 755 /${share_dir}/storage -R

mkdir -p /${share_dir}/mpi
chown root:root /${share_dir}/mpi
chmod 755 /${share_dir}/mpi -R

mkdir -p /opt/donau/1.2.1/
chmod 755 /opt/donau/1.2.1

/etc/init.d/ssh restart

#---------------------------------------------------
date >> /root/file
apt clean || echo starting_clean>>/root/file

apt -y update || echo starting_update>>/root/file

date >> /root/file

apt-mark hold linux-image-4.15.0-112-generic || echo "update kernel">>/root/file

apt-mark hold linux-headers-4.15.0-112-generic || echo "update kernel">>/root/file

apt-mark hold linux-image-generic linux-headers-generic || echo "update kernel generic" >>/root/file

apt-mark hold linux-headers-generic || echo "update kernel generic" >>/root/file

DEBIAN_FRONTEND=noninteractive apt -y upgrade || echo upgradeFaild >>/root/file

echo huawei >> /root/file

#---------------------------------------------------

 

标签:generic,Smartkit,apt,echo,etc,file,Ubuntu,root,OS
From: https://www.cnblogs.com/vmsysjack/p/17677806.html

相关文章

  • Ubuntu 20.04 如何安装NVIDIA的驱动?
    我的环境是:Ubuntu20.041.准备初始环境 sudoapt-getupdate #更新软件列表 sudoapt-getinstallg++ #安装必要依赖 sudoapt-getinstallgcc sudoapt-getinstallmake 2.卸载原先驱动 sudoapt-getremove--purgenvidia* #卸载原有所有驱动(或者nvi......
  • The colossus
    BYSYLVIAPLATHIshallnevergetyouputtogetherentirely,Pieced,glued,andproperlyjointed.Mule-bray,pig-gruntandbawdycacklesProtectedfromyourgreatlips.It'sworsethanabarnyardPehapsyouconsideryourselfanoracle,Mouthpiecep......
  • 【ROS2机器人入门到实战】学会使用按键-GPIO输入
    3.学会使用按键-GPIO输入写在前面当前平台文章汇总地址:ROS2机器人从入门到实战获取完整教程及配套资料代码,请关注公众号<鱼香ROS>获取教程配套机器人开发平台:两驱版|四驱版为方便交流,搭建了机器人技术问答社区:地址fishros.org.cn你好,我是爱吃鱼香ROS的小鱼。上一节完成了LED灯的......
  • 【ROS2机器人入门到实战】嵌入式开发之从点灯开始
    第十三章嵌入式开发之从点灯开始写在前面当前平台文章汇总地址:ROS2机器人从入门到实战获取完整教程及配套资料代码,请关注公众号<鱼香ROS>获取教程配套机器人开发平台:两驱版|四驱版为方便交流,搭建了机器人技术问答社区:地址fishros.org.cn你好,我是小鱼。本章开始我们将一起走进机......
  • 【ROS2机器人入门到实战】使用开源库驱动IMU
    2.使用开源库驱动IMU写在前面当前平台文章汇总地址:ROS2机器人从入门到实战获取完整教程及配套资料代码,请关注公众号<鱼香ROS>获取教程配套机器人开发平台:两驱版|四驱版为方便交流,搭建了机器人技术问答社区:地址fishros.org.cn你好,我是爱吃鱼香ROS的小鱼。上一节我们安装好了MPU605......
  • 视频监控/安防监控EasyCVR平台智能边缘网关硬件ubuntu系统如何取消休眠?
    安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。视频汇聚融合管理平台EasyCVR既具备传统安防视频监控的能力,......
  • Ubuntu截屏工具推荐
    Ubuntu截屏工具推荐本篇博文推荐Ubuntu下的截屏工具Flameshot,可以作为Windows下Snipaste截图工具的平替。GitHub地址:https://github.com/flameshot-org/flameshot安装sudoaptupdatesudoaptinstallflameshot快捷键截图贴图安装之后点击应用图标就可以截图了,下面介绍......
  • mac 安装 postgis
    安装pgsqlbrewuninstall--forcepostgresqlrm-rf/usr/local/var/postgresbrewinstallpostgresbrewinstallpostgis查看版本psql-V#psql(PostgreSQL)14.9(Homebrew)启用拓展psqlpostgresCREATEEXTENSIONpostgis;......
  • ubuntu 22.04 安装docker-ce
    #!/bin/bash##安装依赖sudoapt-getupdatesudoapt-get-yinstallapt-transport-httpsca-certificatescurlsoftware-properties-common##安装GPG证书curl-fsSLhttps://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg|sudoapt-keyadd-##写入软件源信息sudoa......
  • iOS代码加固与保护方法详解 - 提升iOS应用安全性的关键步骤
    摘要:作为一名从事iOS开发多年的技术博主,长期以来我都没有重视代码加密和加固。然而,最近了解到使用IPAGuard工具可以对iOS应用进行混淆保护,我开始重新审视iOS应用的安全性问题。本文将详细介绍如何使用IPAGuard工具进行代码加固和保护,以提高iOS应用的安全性和抵御逆向分析的风险。......