`
lp895876294
  • 浏览: 284847 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

centos快速部署

 
阅读更多

场景:需要在N台服务器上,部署一个相同的项目包。

目标:使用centos命令或脚本与远程机器交互,拷贝部署包、停止或启动servlet容器。

工具:

Expect一个用来实现自动交互功能的软件套件(Expect [is a] software suite for automating interactive tools)。使用它系统管理员可以创建脚本用来实现对命令或程序提供输入,而这些命令和程序是期望从终端(terminal)得到输入,一般来说这些输入都需要手工输入进行的。Expect是基于Tcl语言的一种脚本语言,其实无论是交互还是非交互的应用场合,Expect都可以大显身手,但是对于交互式的特定场合,还非Except莫属。 

NFS:统一存储部署文件。缺点:nfs主机down之后,其他的所有服务器无法访问项目文件。在centos中很少发生,但是为稳定还是用scp将部署文件拷贝到每个服务器上。

实现:

 安装

#安装tcl
yum -y install tcl
yum -y install tcl-devel
#安装expect
yum -y install expect

 新建sh脚本文件

 

#!/usr/bin/expect
set timeout 30 
spawn ssh -l root 172.16.230.108
expect "password:"
#replace ispassword with real password
send "ispassword\r"
#expect *# character , and input next command
expect "*#"
#send command ,  '\r' equal press enter key
send "cd /test/apache-tomcat-7.0.65 \r"
expect "*#"
send "bin/shutdown.sh \r"
expect "*#"
send "bin/startup.sh & tail -f logs/catalina.out \r"
#wait for log output 
interact
#execut logout , return to the invoker

 

spawn:是进入expect环境后才可以执行的expect内部命令,如果没有装expect或者直接在默认的SHELL下执行是找不到spawn命令的。所以不要用 “which spawn“之类的命令去找spawn命令。好比windows里的dir就是一个内部命令,这个命令由shell自带,你无法找到一个dir.com 或 dir.exe 的可执行文件。 它主要的功能是给ssh运行进程加个壳,用来传递交互指令。 

#!/usr/bin/expect这一行告诉操作系统脚本里的代码使用那一个shell来执行。这里的expect其实和linux下的bash、windows下的cmd是一类东西。

expect "password:"这里的expect也是expect的一个内部命令,expect的shell命令和内部命令是一样的,但不是一个功能,习惯就好了。这个命令的意思是判断上次输出结果里是否包含“password:”的字符串,如果有则立即返回,否则就等待一段时间后返回,这里等待时长就是前面设置的30秒 。

interact : 执行完成后保持交互状态,把控制权交给控制台,这个时候就可以手工操作了。如果没有这一句登录完成后会退出,而不是留在远程终端上。

 

SCP参考原文:http://www.cnblogs.com/hitwtx/archive/2011/11/16/2251254.html

linux之cp/scp命令+scp命令详解  

 

名称:cp

使用权限:所有使用者

使用方式:

cp [options] source dest

cp [options] source... directory

说明:将一个档案拷贝至另一档案,或将数个档案拷贝至另一目录。

把计

-a 尽可能将档案状态、权限等资料都照原状予以复制。

-r 若 source 中含有目录名,则将目录下之档案亦皆依序拷贝至目的地。

-f 若目的地已经有相同档名的档案存在,则在复制前先予以删除再行复制。

范例:

将档案 aaa 复制(已存在),并命名为 bbb :

cp aaa bbb

将所有的C语言程式拷贝至 Finished 子目录中 :

cp *.c Finished

命令:scp

不同的Linux之间copy文件常用有3种方法:

第一种就是ftp,也就是其中一台Linux安装ftp Server,这样可以另外一台使用ftp的client程序来进行文件的copy。

第二种方法就是采用samba服务,类似Windows文件copy 的方式来操作,比较简洁方便。

第三种就是利用scp命令来进行文件复制。

    scp是有Security的文件copy,基于ssh登录。操作起来比较方便,比如要把当前一个文件copy到远程另外一台主机上,可以如下命令。

scp /home/daisy/full.tar.gz root@172.19.2.75:/home/root

然后会提示你输入另外那台172.19.2.75主机的root用户的登录密码,接着就开始copy了。

    如果想反过来操作,把文件从远程主机copy到当前系统,也很简单。

linux之cp/scp命令+scp命令详解(转) - linmaogan - 独木★不成林scp root@/full.tar.gz 172.19.2.75:/home/root/full.tar.gz home/daisy/full.tar.gz

linux 的 scp 命令 可以 在 linux 之间复制 文件 和 目录; 

================== 
scp 命令 
================== 
scp 可以在 2个 linux 主机间复制文件; 

命令基本格式: 
       scp [可选参数] file_source file_target 

====== 
从 本地 复制到 远程 
====== 
* 复制文件: 
        * 命令格式: 
                scp local_file remote_username@remote_ip:remote_folder 
                或者 
                scp local_file remote_username@remote_ip:remote_file 
                或者 
                scp local_file remote_ip:remote_folder 
                或者 
                scp local_file remote_ip:remote_file 

                第1,2个指定了用户名,命令执行后需要再输入密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名; 
                第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名; 
        * 例子: 
                scp /home/space/music/1.mp3 root@www.cumt.edu.cn:/home/root/others/music 
                scp /home/space/music/1.mp3 root@www.cumt.edu.cn:/home/root/others/music/001.mp3 
                scp /home/space/music/1.mp3 www.cumt.edu.cn:/home/root/others/music 
                scp /home/space/music/1.mp3 www.cumt.edu.cn:/home/root/others/music/001.mp3 

* 复制目录: 
        * 命令格式: 
                scp -r local_folder remote_username@remote_ip:remote_folder 
                或者 
                scp -r local_folder remote_ip:remote_folder 

                第1个指定了用户名,命令执行后需要再输入密码; 
                第2个没有指定用户名,命令执行后需要输入用户名和密码; 
        * 例子: 
                scp -r /home/space/music/ root@www.cumt.edu.cn:/home/root/others/ 
                scp -r /home/space/music/ www.cumt.edu.cn:/home/root/others/ 

                上面 命令 将 本地 music 目录 复制 到 远程 others 目录下,即复制后有 远程 有 ../others/music/ 目录 


====== 
从 远程 复制到 本地 
====== 
从 远程 复制到 本地,只要将 从 本地 复制到 远程 的命令 的 后2个参数 调换顺序 即可; 

例如: 
        scp root@www.cumt.edu.cn:/home/root/others/music /home/space/music/1.mp3 
        scp -r www.cumt.edu.cn:/home/root/others/ /home/space/music/

最简单的应用如下 : 

scp 本地用户名 @IP 地址 : 文件名 1 远程用户名 @IP 地址 : 文件名 2 

[ 本地用户名 @IP 地址 :] 可以不输入 , 可能需要输入远程用户名所对应的密码 . 

可能有用的几个参数 : 

-v 和大多数 linux 命令中的 -v 意思一样 , 用来显示进度 . 可以用来查看连接 , 认证 , 或是配置错误 . 

-C 使能压缩选项 . 

-P 选择端口 . 注意 -p 已经被 rcp 使用 . 

-4 强行使用 IPV4 地址 . 

-6 强行使用 IPV6 地址 .

 

注意两点:
1.如果远程服务器防火墙有特殊限制,scp便要走特殊端口,具体用什么端口视情况而定,命令格式如下:
#scp -p 4588 remote@www.abc.com:/usr/local/sin.sh /home/administrator
2.使用scp要注意所使用的用户是否具有可读取远程服务器相应文件的权限。

 

分享到:
评论

相关推荐

    Centos7.5部署堡垒机JumpServer.docx

    完整记录了centos7.5环境下部署开源堡垒机Jumpserver、linux终端koko、windows组件Guacamole的部署过程,包括每一条命令和必要说明!能够帮助大家快速建立起一个堡垒机服务!

    ansible快速部署(适用centos7)

    在“ansible快速部署(适用centos7)”的场景中,我们可以深入理解Ansible如何在CentOS 7系统上进行快速部署。 1. **Ansible 安装**: 在CentOS 7上安装Ansible,可以通过Yum包管理器进行,运行`sudo yum install -y ...

    CentOS 7 部署 Elasticsearch7.4 集群并进行安全认证.docx

    CentOS 7 部署 Elasticsearch 7.4 集群并进行安全认证 Elasticsearch 是一个基于 Lucene 库的搜索和数据分析引擎,它提供了一个分布式的...通过本文,我们可以快速地部署 Elasticsearch 集群,并对其进行安全认证。

    CentOS 7 FTP-Server部署

    ### CentOS 7 FTP-Server部署知识点详解 #### 一、FTP服务器简介 FTP(File Transfer Protocol)是一种用于在网络上进行文件传输的协议。...希望这篇教程能够帮助您快速上手CentOS 7上的FTP服务器部署。

    CentoS7.6大数据环境部署 .docx

    在本文中,我们将深入探讨如何在CentOS 7.6平台上进行大数据环境的部署,主要涉及Hadoop、HBase、ZooKeeper、Phoenix、DataX、Kafka以及Spark的安装和配置。首先,我们来看看环境准备阶段。 环境准备是整个部署的...

    centos7 elk 部署全过程

    在本文中,我们将详细探讨如何在CentOS 7操作系统上部署Elasticsearch 6.5.4、Logstash 6.5.4、Kibana 6.5.4以及log4j2,以此组成一个ELK(Elasticsearch、Logstash和Kibana)日志处理和可视化平台。这个过程将涉及...

    centos7部署zabbix3.5

    在本文中,我们将详细介绍如何在CentOS 7环境中部署Zabbix 3.5,这是一个强大的开源监控解决方案。Zabbix能够监控各种网络参数,确保服务器系统的安全运行,并通过灵活的通知机制帮助管理员快速识别和解决问题。 ...

    Centos 5.5环境下部署LVS+Keepalived

    ### Centos 5.5环境下部署LVS+Keepalived #### 一、概述 本文档将详细介绍如何在CentOS 5.5操作系统环境中搭建基于LVS (Linux Virtual Server) 和 Keepalived 的高可用性负载均衡集群。通过此方案可以有效提升...

    CentOS6.8下快速安装Composer并部署Laravel框架

    ### CentOS 6.8 下快速安装 Composer 并部署 Laravel 框架 #### 一、简介 本篇文章将详细介绍如何在 CentOS 6.8 系统下安装 Composer 并使用 Composer 部署 Laravel 框架。文章分为以下几个部分进行讲解: 1. **...

    linux-Centos下一键部署lnmp环境脚本

    总之,"centos-lnmp-master"这样的脚本是Linux开发者和运维人员的利器,它能快速地在CentOS系统上构建一个功能完备的LNMP环境,降低部署和管理复杂性。通过深入理解脚本的工作原理和自定义配置,我们可以更好地优化...

    centos下部署openstack计算节点文档

    本文将深入解析如何在CentOS操作系统上快速且准确地部署OpenStack计算节点,包括必要的软件安装、配置以及网络设置,确保计算节点能够顺利集成到OpenStack环境中。 ### 一、OpenStack计算节点概述 OpenStack是一个...

    centos8部署的cobbler3相关tar包

    Cobbler 是一款自动化Linux系统部署工具,常用于大规模服务器环境的快速配置。在CentOS 8操作系统上部署Cobbler3,可以帮助管理员简化安装流程,提高效率。本压缩包包含的是与Cobbler3部署相关的文件,主要分为两个...

    centos7部署weblogic.docx

    CentOS7 部署 WebLogic 12 详解 在本文中,我们将详细介绍如何在 CentOS 7 操作系统上部署 WebLogic 12 应用服务器。...通过本文,我们可以快速地部署 WebLogic 服务器,满足企业级应用系统的需求。

    基于CentOS的智能DNS系统详细部署过程

    ### 基于CentOS的智能DNS系统详细部署过程 #### 一、应用场景与问题背景 在当前互联网时代,网络广告公司面临着一个普遍的问题:南北网络互通性不佳,导致访问速度慢,用户体验差,严重影响了业务的发展。尤其对于...

    centos7操作系统上一键部署jdk1.8

    在本案例中,我们将探讨如何在CentOS 7操作系统上通过自编写的shell脚本一键部署JDK 1.8。 首先,让我们详细了解JDK 1.8的关键特性。这个版本引入了多项重要的更新,例如Lambda表达式,它简化了处理匿名函数的方式...

    Centos7部署kongv0.14.x 完整文档

    通过本教程的学习与实践,读者将能够掌握Kong在Centos7下的安装与配置流程,从而快速搭建出适用于生产环境的API管理系统。 #### 二、前置条件 确保系统中已安装JDK 1.8和Tomcat。此外,还需安装以下软件包以满足...

    Centos7+CDP7.1.1安装部署

    Centos7+CDP7.1.1的安装部署是一个涉及多步骤的过程,主要涵盖了系统配置、服务安装、数据库设置以及集群组建等多个方面。...在部署过程中遇到任何报错,应详细记录并查阅相关文档或社区解决方案,以快速解决问题。

    基于centos7的单实例openstack安装

    基于 CentOS 7 的单实例 OpenStack 安装 OpenStack 是一个开源的云计算平台...本文介绍了基于 CentOS 7 的单实例 OpenStack 安装方法,这种安装方法可以快速部署 OpenStack 环境,适合概念验证(POC)和小型测试环境。

Global site tag (gtag.js) - Google Analytics