用shell的linux服务器 .sh插件怎么从远程ftp服务器下载文件

用shell的linux服务器 .sh插件怎么从远程ftp服务器下载文件,第1张

//ftpputsh
[cpp] view plain copy
#!/bin/sh
#FileName:ftpputsh
#Function:从本地客户端向ftp服务器上传一个文件
#Version:V01
#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=127001
#IP=19216861

#FULLNAME获取本地文件全路径
FULLNAME=$1

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

#basename返回一个路径中的文件名部分
#如FULLNAME="/home/Sunrier/Proj/log/testlog";
#当local_filename=`basename $FULLNAME`
#最终local_filename="testlog"
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:ftpputsh
#Function:从本地客户端向ftp服务器上传一个文件
#Version:V01
#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=127001
IP=19216861

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

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

#basename返回一个路径中的文件名部分
#如FULLNAME="/home/Sunrier/Proj/log/testlog";
#当local_filename=`basename $FULLNAME`
#最终local_filename="testlog"
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
//ftpgetsh
[cpp] view plain copy
#!/bin/sh
#FileName:ftpgetsh
#Function:从ftp服务器上下载一个文件到本地计算机上
#Version:V01
#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=127001
#IP=19216861

#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:ftpputsh
#Function:从本地客户端向ftp服务器上传一个文件(添加远程目录是否存在判断功能)
#Version:V02
#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=127001
#IP=19216861

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

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

#dirname返回路径中的目录部分
#DESTDIR="/home/Sunrier/Proj/log/testlog";
#当PREDESTDIR=`dirname $DESTDIR`
#最终PREDESTDIR="/home/Sunrier/Proj/log"
PREDESTDIR=`dirname $DESTDIR`
SUFFIXDESTDIR=`basename $DESTDIR`

LOCALDIR=`dirname $FULLNAME`

#basename返回一个路径中的文件名部分
#如FULLNAME="/home/Sunrier/Proj/log/testlog";
#当local_filename=`basename $FULLNAME`
#最终local_filename="testlog"
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/tmptxt
quit
FTPIT

#find $LOCALDIR -name "tmptxt" -type f | xargs grep "^d$SUFFIXDESTDIR$"
#find -name "tmptxt" -type f | xargs grep "^d$SUFFIXDESTDIR$"
#find ! -name "" -type d -prune -o -type f -iname "tmptxt" -print | xargs grep "^d$SUFFIXDESTDIR$"
#grep "^d$SUFFIXDESTDIR$" \$LOCALDIR/tmptxt
#grep后面查找字符两边加不加引号效果相同

grep ^d$SUFFIXDESTDIR$ $LOCALDIR/tmptxt >/dev/null 2>&1

#$表示上一个命令的运行结果,0表示成功,其它值表示失败
#if [ $ != 0 ]
if [ $ -ne 0 ]
then
rm $LOCALDIR/tmptxt
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/tmptxt
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
tcp 0 0 127001:2208 0000: LISTEN
tcp 0 0 0000:523 0000: LISTEN
tcp 0 0 0000:111 0000: LISTEN
tcp 0 0 0000:50000 0000: LISTEN
tcp 0 0 0000:21 0000: LISTEN
tcp 0 0 127001:631 0000: LISTEN
tcp 0 0 127001:25 0000: LISTEN
tcp 0 0 0000:601 0000: LISTEN
tcp 0 0 127001:2207 0000: LISTEN
tcp 0 0 :::22 ::: LISTEN
[root@localhost ~]#

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

Linux *** 作系统无法直接运行Windows的可执行文件(exe文件),因为它们不是相同的 *** 作系统。如果您想在Linux上运行Windows应用程序,则需要使用模拟器或虚拟机软件,如Wine、VirtualBox等。这些软件可以在Linux系统上创建一个虚拟的Windows环境,并允许您在其中运行Windows应用程序。
另外,如果您只是想下载Windows应用程序的可执行文件,可以通过浏览器下载功能或命令行工具(如wget)来下载。您可以在Linux终端中使用wget命令来下载文件,例如:
```
wget >

首先需要选择一套你想安装的Linux发行版的安装盘。由于Linux是开源的,Linux的发行版也相当多,包括RedHat,Mandrake,Suse,Debian,Gentoo等等。

建议选择RedHatLinux是因为它比较普及,而且对于初学者也比较容易掌握。

RedHatLinux也有很多的版本,现在还常见的包括7,8,9和FedoraCore1,2

系列。恩,就不往深里解释了,链接给的是RedHat9的安装文件的下载,因为

这个版本相对而言是比较稳定和成熟的一个版本。

链接中的安装文件是iso文件,建议大家下载后刻成安装盘(共三张)安装,当然也可以参阅网上文档从网络直接安装。

2其次需要给Linux系统留出足够的磁盘空间来安装,因为Linux采用ext2/ext3

的文件系统,和windows的fat/ntfs文件系统是不同的,所以不能像在windows

中装软件那样直接装Linux,而需要给Linux系统留出足够的空闲空间。

最简捷的一个方法是直接利用windows自带的工具:

开始-控制面板-管理工具-计算机管理-磁盘管理

上述的路径是在windows2003的,2000和xp也在类似的位置。

磁盘管理中可以删除某个硬盘的逻辑分区(C盘,D盘,E盘这样的逻辑分区)为

空闲的磁盘空间。

选取一个你不常用的逻辑分区(建议不要小于5G),将其中的文件备分到其它

分区中去,然后在磁盘管理中将这个逻辑分区删除成空闲的磁盘空间。

!!!千万要注意不要删错盘!!!也不能删除C盘!!!!!

如果你原来就没有多余的分区可以分给Linux,但是有足够的磁盘空间,那么你

就需要用pqmagic类似的磁盘分区工具来帮忙了,反正弄出5个G以上的空闲磁盘

空间就可以了。

3准备工作都做完了,现在开始装,首先重启系统,选择bios从光盘启动。然后把

Linux的安装光盘放在光驱里。

4如果光盘没有问题的话,启动后会和windows的启动不一样了,刷出来一大屏字符

信息,恩,这就对了:)到一个有红帽子招牌的地方会停下等待输入,安装

系统直接按回车就可以了。

剩下的其实和windows的安装也没啥区别,想看看它在说什么就读一读,不想看直接

下一步。

!!!不过一定要注意在一个地方不能按下一步!!!

当问你选择什么磁盘空间来安装Linux的时候,通常有这样的三种选择:

删除当前所有分区并重新分区

删除当前所有Linux分区并重新分区

利用当前空闲的磁盘空间来安装系统

!!!一定要选第三个,不能是缺省的第一个!!!

当然也不用太紧张,如果误点一次通常会有提示框的,还能取消,但你要误点两次就

不要怪我这里没有提醒你了

之后还有几个地方需要注意:

会问你是系统自动分区还是你自己手动分区,没装过Linux的同学就自动分吧,一般会

有一个警告框,不用担心,直接确定。

还有就是在选择用什么样的引导器的时候,可以直接用缺省的GRUB引导器,但是下面的

框框里需要把windows修改成默认值,这样不用今后每次开机的时候都去盯着机器。

(当然这些东西都不是必须的,装完系统以后都还可以自己再改)

还会需要你提供一个root密码,root的作用相当于windows中的,对所有

的文件都有访问权限。对于服务器来说,root密码是最重要的,但是个人pc好象问题不

大不过还是提醒大家要谨慎,因为用root登陆时,只要一条命令就可以把整个机器

里的东西全部删除,甚至包括windows里的东西。

5点完一堆下一步后会到一个界面问你需要安装那些软件,对于第一次用Linux的同学,建议你选择完全安装——注意是完全安装,不是缺省地点下一步。完全安装需要4G多的空

间,如果你没有没有这么多的空间或者你就是不想装一堆你永远可能都不会用的东西,那么你可以把开发工具那一栏里的东东都选上,最重要的是内核开发那一栏,因为我们

需要g等工具来做编译源码等工作。

6假设你选择完全部安装,点击下一步后就开始了还比较漫长的安装过程,等吧,记得隔

一会换张光盘。

7装完了以后还会有一个系统的检测,不要轻易修改显示的属性,因为那些是系统自动检

测出来的,随便改了很有可能导致无法进入图形界面。

8最后还应该会让你设置一个用户,最好设置一个,因为使用Linux的原则之一就是慎用

root,通常情况下都不要用root用户登陆,那样会比较安全。

9恩,如果记得没错的话系统应该已经装完了,拿出光盘,重新启动,就可以看到GRUB引

导器的土土的界面,选择Linux,等待启动完毕,恩,欢迎来到Linux的世界:)

《Linux应用大全:服务器架设epub》百度网盘免费下载:
9qve


欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/zz/13465662.html

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

发表评论

登录后才能评论

评论列表(0条)

保存