分类 【操作系统】 下的文章

Linux下使用shell脚本执行需要交互的命令

有些命令或者安装程序在执行时是需要有交互的,比如选择安装路径、选择Y/N等等,如果想用shell脚本中执行该命令,而命令又没有提供默认执行/安装参数时,可以先安装expect,然后按照以下的范例编写:

#!/usr/bin/expect
#spawn sh fncbins.run.LINUX.20160927191846.bin
spawn bash -c "sh fncbins*"
#expect "*"
#send " fncb*.bin\n"
expect "请输入操作系统类型(AIX/HPUX/LINUX),直接回车默认(LINUX):"
send "LINUX\n"
expect "请输入数据库类型(ORACLE/DB2/INFORMIX/PGSQL/MYSQL),直接回车默认(ORACLE):"
send "ORACLE\n"
expect "请输入中间件类型(TUXEDO/FNCBTCP/CICS/MQ),直接回车默认(TUXEDO):"
send "TUXEDO\n"
expect "请输入运行环境类型(开发环境/测试环境/生产环境):(DEV/TST/PRO),直接回车默认(DEV):"
send "DEV\n"
expect "开始安装(Y/N),默认(N)"
send "Y\n"
expect "修改对应的环境变量后,请重新登录用户、启动系统、测试使用"
send "\n"
expect eof
exit

请注意expect后要加上期望匹配的回显

找回Mac 10.12(Sierra)允许“任何来源” 的应用

有不少用户在安装了 macOS Sierra之后发现,系统偏好设置的“安全与隐私”中默认已经去除了允许“任何来源”App 的选项。如果需要恢复允许“任何来源”的选项,即关闭 Gatekeeper(一些从互联网下载和安装的 app 可能对 Mac 产生不利影响,Gatekeeper 帮助保护 Mac 免受此类 app 的影响。),我们可以在终端中使用 spctl 命令来实现:

sudo spctl --master-disable

输入上述命令之后,我们可以发现,久违的“任何来源”回来了

在ubuntu上制作openstack虚拟机centos6.5自定义镜像

基础环境信息:
客户端:ubuntu 16.04.01 LTS
服务器:openstack L版

第一步,确认硬件
KVM需要CPU硬件支持虚拟化,所以首先要确认你的CPU支持:

$ egrep -o '(vmx|svm)' /proc/cpuinfo

如果有输出回显,则代表CPU支持虚拟化

第二步,更新并安装ubuntu的kvm支持:

$ sudo apt-get update && sudo apt-get dist-upgrade -y
$ sudo apt-get install  qemu-kvm qemu-system libvirt-bin bridge-utils virt-manager virtinst virt-viewer

第三步,检查 libvirt 默认网络是否运行
运行

virsh net-list 

查看是否有active的记录,如果不存在,则使用

# virsh net-start default

添加默认记录后,再次查看是否有active的记录

第四步,创建空白镜像:

# qemu-img create -f qcow2 /tmp/centos-6.5.qcow2 10G

这里需要解释一下,最后两个参数:
/tmp/centos-6.5.qcow2:表示生成的空白镜像所在的路径
10G:是指空白镜像文件的大小,也就是以后我们虚拟机默认的初始化磁盘空间

第五步,创建kvm虚拟机,并且挂载镜像:

# virt-install --virt-type kvm --name centos-6.5-64bit --ram 1024 \
--disk /tmp/centos-6.5.qcow2,format=qcow2 \
--network network=default \
--graphics vnc,listen=0.0.0.0 --noautoconsole \
--os-type=linux --os-variant=rhel6 \
--extra-args="console=tty0 console=ttyS0,115200n8 serial" \
--location=/data/isos/CentOS-6.5-x86_64-netinstall.iso

可变参数解释:
--name:虚拟机的名称,这里要记住,下面还会用到
--ram:虚拟机的内存大小,这只是安装时使用,和之后的打包成镜像后的运行时参数无关
--disk:第四步中创建的空白虚拟机磁盘文件路径
--os-type:操作系统类型
--os-variant:操作系统标识,可以根据实际情况修改
--location:安装镜像,即需要挂载的安装光盘

第六步,虚拟机操作系统安装,过程略

第七步,安装虚拟机内部必要组件,并关机
使用

virsh dumpxml 虚拟机名称 (在本例中,为centos-6.5-64bit)

命令查看挂载的CD-ROM,并使用

# virsh attach-disk --type cdrom --mode readonly 虚拟机名称 "" 设备名(比如hdc,根据virsh dumpxml命令实际返回结果来修改)
# virsh destroy 虚拟机名称
# virsh start 虚拟机名称

卸载

# yum install acpid
# chkconfig acpid on
# yum install http://download.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
安装必要的第三方软件,比如htop等
# echo "NOZEROCONF=yes" >> /etc/sysconfig/network   (非必要,配合cloud-init使用)
# /sbin/shutdown -h now

第八步, 清理(删除 MAC 地址相关信息):

# virt-sysprep -d 虚拟机名称

第九步,qcow2减肥,并上传至openstack控制节点:

# qemu-img convert -c -O qcow2 centos6.5-64bit.qcow2 /home/tan9le/centos65-64bit.qcow2

centos6.5-64bit.qcow2 为原始镜像
/home/tan9le/centos65-64bit.qcow2 为压缩后的镜像

第十步,导入glance镜像(openstack控制节点操作)

source admin-opensrc    #导入openstack的admin权限变量
glance image-create --name "centos65-64bit" --file /images/centos65-64bit.qcow2  --disk-format qcow2 --container-format bare --visibility public --progress

--name 镜像名称,在openstack平台上可以显示
--file 第九步中上传的qcow2镜像路径

解决AIX 6.1上传文件1GB限制问题

aix的确有单文件大小的限制,默认是1G
查看限制可以登录aix系统输入命令ulimit -a,输出当前用户的限制,如下,注意,是当前用户的
# ulimit -a
time(seconds) unlimited
file(blocks) 2097151 -------这个就是单文件大小,换算过来就应该是1G(1block=半k)
data(kbytes) 131072
stack(kbytes) 32768
memory(kbytes) 32768
coredump(blocks) 2097151
nofiles(descriptors) 2000
threads(per process) unlimited
processes(per user) unlimited

方案一:
修改限制需要root用户登录,编辑/etc/security/limits文件
找到你ftp的那个用户(若没有可以新写一行),按照default:的格式在用户下加上一行:

fsize = -1

保存退出即可(-1表示unlimited,不受限制,如2的输出)
另外,如果你想要aix系统所有用户的单文件都不受1G限制,直接把default的fsize = -1即可

方案二:
使用SMIT工具,修改对应用户的文件大小限制

修改了limit后,对应的用户重新登录生效,无须重启,可ulimit -a查看