用xshell远程连接linux服务器,sh命令启动一个服务后,如果关掉xshell,这个服务也会跟着停止了

用xshell远程连接linux服务器,sh命令启动一个服务后,如果关掉xshell,这个服务也会跟着停止了,第1张

用nohup命令来执行,如:nohup test.sh &

nohup 命令

用途:不挂断地运行命令。

语法:nohup Command [ Arg … ] [ &]

nohup放在命令的开头,表示不挂起(no hang up),也即,关闭终端或者退出某个账号,进程也继续保持运行状态,一般配合&符号一起使用。如nohup command &。

扩展资料:

描述

nohup 命令运行由 Command参数和任何相关的 Arg参数指定的命令,忽略所有挂断(SIGHUP)信号。

在注销后使用 nohup 命令运行后台中的程序,要运行后台中的 nohup 命令,添加 &( 表示“and”的符号)到命令的尾部。

参考资料来源:百度百科-nohup

//ftpput.sh

[cpp] view plain copy

#!/bin/sh

#FileName:ftpput.sh

#Function:从本地客户端向ftp服务器上传一个文件

#Version:V0.1

#Author:Sunrier

#Date:2012-07-20

#$#表示传递给此Shell脚本的参数个数

#-ne表示不等于

if [ $# -ne 2 ]

then

echo "Usage $0 <local_dir/filename><remote_dir>"

exit 1

fi

#IP表示ftp的服务器ip地址

IP=127.0.0.1

#IP=192.168.6.1

#FULLNAME获取本地文件全路径

FULLNAME=$1

#DESTDIR获取需要上传的ftp远程目录路径

DESTDIR=$2

#basename返回一个路径中的文件名部分

#如FULLNAME="/home/Sunrier/Proj/log/test.log"

#当local_filename=`basename $FULLNAME`

#最终local_filename="test.log"

local_filename=`basename $FULLNAME`

#DESTFILE表示ftp服务器的路径,以及保存后的文件名

DESTFILE=$DESTDIR/$local_filename

#ftp -i -n $IP <<FTPIT

ftp -i -n <<FTPIT

open $IP

user Sunrier redhat

bin

passive

cd /home/remote/log/ftpfile

put $FULLNAME $DESTFILE

quit

FTPIT

exit 0

//注释:

[cpp] view plain copy

#!/bin/sh

#FileName:ftpput.sh

#Function:从本地客户端向ftp服务器上传一个文件

#Version:V0.1

#Author:Sunrier

#Date:2012-07-20

#$#表示传递给此Shell脚本的参数个数

#-lt表示小于

#-eq表示等于

#-ne表示不等于

if [ $# -ne 2 ]

then

echo "Usage $0 <local_dir/filename><remote_dir>"

exit 1

fi

#IP表示ftp的服务器ip地址

#IP=127.0.0.1

IP=192.168.6.1

#FULLNAME获取本地文件全路径名

FULLNAME=$1

#DESTDIR获取需要上传的ftp远程目录路径

DESTDIR=$2

#basename返回一个路径中的文件名部分

#如FULLNAME="/home/Sunrier/Proj/log/test.log"

#当local_filename=`basename $FULLNAME`

#最终local_filename="test.log"

local_filename=`basename $FULLNAME`

#DESTFILE表示ftp服务器的路径,以及保存后的文件名

DESTFILE=$DESTDIR/$local_filename

#-i表示在多个文件传输期间关闭交互提示

#-n表示禁止自动登录到初始连接

#<<FTPIT 和最后的 FTPIT:术语叫:当前文档here documents. here document 就是一段特殊目的的代码块,

#它使用I/O重定向的形式来将一个命令序列传递到一个交互程序或者命令中,比如ftp、cat,或者ex文本编辑器.

#本句可以理解从<<FTPIT开始以非对话模式的ftp连接,直到输入FTPIT为止的所有命令.

#当然FTPIT这个名字是可以随便取的,不一定必须是FTPIT,可以取其它的名字。

#ftp -i -n $IP <<FTPIT

ftp -i -n <<FTPIT

#连接到指定ftp服务器上

open $IP

#连接到指定ftp服务器上,并指定端口

#open $IP $PORT

#登陆ftp服务器上的用户名和密码

#user username password

user Sunrier redhat

#bin表示以二进制方式传输

#bin等价于bi,binary等

#另一种方式传输是ascii,默认情况下,将文件传输类型设置为ASCII

bin

#主动模式的FTP是指服务器主动连接客户端的数据端口,被动模式的FTP是指服务器被动地等待客户端连接自己的数据端口

#被动模式的FTP通常用在处于防火墙之后的FTP客户访问外界FTP服务器的情况.

#因为在这种情况下,防火墙通常配置为不允许外界访问防火墙之后主机,而只允许由防火墙之后的主机发起的连接请求通过.

#因此在这种情况下不能使用主动模式的FTP传输,而被动模式的FTP可以良好的工作.

#passive表示设置为被动模式的FTP

passive

#cd表示更改ftp服务器上(即远程计算机)的工作目录

cd /home/remote/log/ftpfile

#lcd表示更改本地计算机的工作目录

#lcd /home/Sunrier/Proj/log/

#put local_file [ remote_file ]

#其中local_file是指定要复制的本地文件,remote_file是指定要复制的远程计算机上的文件名,

#remote_file为可选项,如果不指定的话是和本地计算机上的文件名同名.

#put表示把本地路径下的文件复制到FTP服务器(远程计算机)上设置的路径下的文件

put $FULLNAME $DESTFILE

#quit表示结束与远程计算机的FTP会话,并退出FTP.

#还有个等价的命令为bye(或by)结束与远程计算机的FTP会话并退出FTP

quit

#here document块结束

FTPIT

#正式写这个Shell脚本时,here document中的#和空行都会执行,

#所以为了消除警告最好去掉here document块中#开头的语句以及空行,

#暂时我还没有找到here document中有效的注释语句的方法.

exit 0

//ftpget.sh

[cpp] view plain copy

#!/bin/sh

#FileName:ftpget.sh

#Function:从ftp服务器上下载一个文件到本地计算机上

#Version:V0.1

#Author:Sunrier

#Date:2012-07-20

#$#表示传递给此Shell脚本的参数个数

#-ne表示不等于

if [ $# -ne 2 ]

then

echo "Usage $0 <remote_dir/filename><local_dir>"

exit 1

fi

#IP表示ftp的服务器ip地址

IP=127.0.0.1

#IP=192.168.6.1

#FULLNAME获取从ftp服务器上下载的文件全路径名

FULLNAME=$1

#DESTDIR获取从ftp服务器上下载的文件所存放的本地计算机的目录路径

DESTDIR=$2

#remote_filename获取从ftp服务器上下载的文件名

remote_filename=`basename $FULLNAME`

#DESTFILE表示下载文件所存放的本地路径,以及本地保存后的文件名

DESTFILE=$DESTDIR/$remote_filename

#ftp -i -n $IP <<FTPIT

ftp -i -n <<FTPIT

open $IP

user Sunrier redhat

bin

cd /home/remote/log/ftpfile

get $FULLNAME $DESTFILE

quit

FTPIT

exit 0

#get remote_file [ local_file ]

#remote_file是指定要复制的文件,local_file是指定本地计算机上的文件名,

#local_file为可选项,没有指定的话则跟remote_file同名。

//20120726改进版本

[cpp] view plain copy

#!/bin/sh

#FileName:ftpput.sh

#Function:从本地客户端向ftp服务器上传一个文件(添加远程目录是否存在判断功能)

#Version:V0.2

#Author:Sunrier

#Date:2012-07-26

#$#表示传递给此Shell脚本的参数个数

#-ne表示不等于

if [ $# -ne 2 ]

then

echo "Usage $0 <local_dir/filename><remote_dir>"

exit 1

fi

#IP表示ftp的服务器ip地址

IP=127.0.0.1

#IP=192.168.6.1

#FULLNAME获取本地文件全路径名

FULLNAME=$1

#DESTDIR获取需要上传的ftp远程目录路径

DESTDIR=$2

#dirname返回路径中的目录部分

#DESTDIR="/home/Sunrier/Proj/log/test.log"

#当PREDESTDIR=`dirname $DESTDIR`

#最终PREDESTDIR="/home/Sunrier/Proj/log"

PREDESTDIR=`dirname $DESTDIR`

SUFFIXDESTDIR=`basename $DESTDIR`

LOCALDIR=`dirname $FULLNAME`

#basename返回一个路径中的文件名部分

#如FULLNAME="/home/Sunrier/Proj/log/test.log"

#当local_filename=`basename $FULLNAME`

#最终local_filename="test.log"

local_filename=`basename $FULLNAME`

#DESTFILE表示ftp服务器的路径,以及保存后的文件名

DESTFILE=$DESTDIR/$local_filename

#ftp -i -n $IP <<FTPIT

ftp -i -n <<FTPIT

open $IP

user Sunrier redhat

dir $PREDESTDIR $LOCALDIR/tmp.txt

quit

FTPIT

#find $LOCALDIR -name "tmp.txt" -type f | xargs grep "^d.*$SUFFIXDESTDIR$"

#find . -name "tmp.txt" -type f | xargs grep "^d.*$SUFFIXDESTDIR$"

#find . ! -name "." -type d -prune -o -type f -iname "*tmp.txt" -print | xargs grep "^d.*$SUFFIXDESTDIR$"

#grep "^d.*$SUFFIXDESTDIR$" \$LOCALDIR/tmp.txt

#grep后面查找字符两边加不加引号效果相同

grep ^d.*$SUFFIXDESTDIR$ $LOCALDIR/tmp.txt >/dev/null 2>&1

#$?表示上一个命令的运行结果,0表示成功,其它值表示失败

#if [ $? != 0 ]

if [ $? -ne 0 ]

then

rm $LOCALDIR/tmp.txt

exit 1

fi

#mkdir创建远程目录

#mkdir $DESTDIR

#ftp -i -n $IP <<FTPIT

ftp -i -n <<FTPIT

open $IP

user Sunrier redhat

bin

passive

cd /home/remote/log/ftpfile

put $FULLNAME $DESTFILE

quit

FTPIT

rm $LOCALDIR/tmp.txt

exit 0

[cpp] view plain copy

注:

FTP服务器的启动:

[root@localhost ~]# service vsftpd start

为 vsftpd 启动 vsftpd:[确定]

FTP服务器的端口一般默认为21:

[root@localhost ~]# netstat -nat

Active Internet connections (servers and established)

Proto Recv-Q Send-Q Local Address Foreign Address State

tcp0 0 127.0.0.1:2208 0.0.0.0:* LISTEN

tcp0 0 0.0.0.0:523 0.0.0.0:* LISTEN

tcp0 0 0.0.0.0:111 0.0.0.0:* LISTEN

tcp0 0 0.0.0.0:50000 0.0.0.0:* LISTEN

tcp0 0 0.0.0.0:21 0.0.0.0:* LISTEN

tcp0 0 127.0.0.1:631 0.0.0.0:* LISTEN

tcp0 0 127.0.0.1:250.0.0.0:* LISTEN

tcp0 0 0.0.0.0:601 0.0.0.0:* LISTEN

tcp0 0 127.0.0.1:2207 0.0.0.0:* LISTEN

tcp0 0 :::22 :::*LISTEN

[root@localhost ~]#

在使用system执行Shell脚本时,如system("ftpput.sh"),system返回值低8位为system执行脚本所接收到的信号值,9~16位为Shell脚本所设置的exit退出值

默认配置

Windows下有很多SSH工具。在这里我是用的是Putty。如果安装了Git并配置使用Putty的话,就不需要另外在安装Putty了。使用SSH连接服务器的命令如下:

ssh

IP地址1

一般来说为了安全性考虑,端口号等一些参数并不会使用默认值。这样的话命令就变成这样:

ssh

用户名@IP地址

-p

端口号1

如果连接成功的话会提示你输入远程服务器的密码。全部成功之后SSH就会显示远程服务器的提示符,这时候就说明连接成功了。

密钥登录

每次登录SH都需要输入密码很麻烦,而且可能不太安全。SSH还能使用另外一种登录方式,也就是使用密钥登录。这种登录方式需要客户端生成一堆公钥私钥对,然后将公钥添加到服务器中,这样下次就可以直接登录了。

首先生成SSH密钥,依照提示输入信息即可。默认生成在用户主目录中的.ssh文件夹中。带pub的是公钥,接下来需要添加到服务器中。

ssh-keygen1

然后将本地公钥添加到服务器中,需要使用另一个命令:

scp

-P

端口号

本地文件路径

用户名@远程服务器地址:远程路径1

然后登陆服务器,找到复制进去的公钥,将公钥名字改为authorized_keys并添加到对应的.ssh文件夹中。然后退出SSH重新登陆试试,成功的话不需要输入密码就会直接进入远程服务器。


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/140034.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-18
下一篇2023-03-18

发表评论

登录后才能评论

评论列表(0条)

    保存