ArthurXF从业10年的CTO,受上海非凡学院邀请,进行PHP,CSS,FREEBSD等网络技能授课培训,有意向参加的,请联系.
wget是一个从网络上自动下载文件的自由工具。它支持HTTP,HTTPS和FTP协议,可以使用HTTP代理.
所谓的自动下载是指,wget可以在用户退出系统的之后在后台执行。这意味这你可以登录系统,启动一个wget下载任务,然后退出系统,wget将在后台执行直到任务完成,相对于其它大部分浏览器在下载大量数据时需要用户一直的参与,这省去了极大的麻烦。
wget 可以跟踪HTML页面上的链接依次下载来创建远程服务器的本地版本,完全重建原始站点的目录结构。这又常被称作"递归下载"。在递归下载的时候,wget 遵循Robot Exclusion标准(/robots.txt). wget可以在下载的同时,将链接转换成指向本地文件,以方便离线浏览。
wget 非常稳定,它在带宽很窄的情况下和不稳定网络中有很强的适应性.如果是由于网络的原因下载失败,wget会不断的尝试,直到整个文件下载完毕。如果是服务器打断下载过程,它会再次联到服务器上从停止的地方继续下载。这对从那些限定了链接时间的服务器上下载大文件非常有用。
wget的常见用法
wget虽然功能强大,但是使用起来还是比较简单的,
基本的语法是:wget [参数列表] "URL" 用""引起来可以避免因URL中有特殊字符造成的下载出错。
下面就结合具体的例子来说明一下wget的用法。
wget还有很多有用的功能,需要用户去挖掘。
wget的使用格式
Usage: wget [OPTION]... [URL]...
* 用wget做站点镜像:
wget -r -p -np -k http://dsec.pku.edu.cn/~usr_name/
# 或者
wget -m http://dsec.pku.edu.cn/~usr_name/
* 在不稳定的网络上下载一个部分下载的文件,以及在空闲时段下载
wget -t 0 -w 31 -c http://dsec.pku.edu.cn/BBC.avi -o down.log &
# 或者从filelist读入要下载的文件列表
wget -t 0 -w 31 -c -B ftp://dsec.pku.edu.cn/linuxsoft -i filelist.txt -o down.log &
上面的代码还可以用来在网络比较空闲的时段进行下载。我的用法是:在mozilla中将不方便当时下载的URL链接拷贝到内存中然后粘贴到文件filelist.txt中,在晚上要出去系统前执行上面代码的第二条。
* 使用代理下载
wget -Y on -p -k https://sourceforge.net/projects/wvware/
代理可以在环境变量或wgetrc文件中设定
# 在环境变量中设定代理
export PROXY=http://211.90.168.94:8080/
# 在~/.wgetrc中设定代理
http_proxy = http://proxy.yoyodyne.com:18023/
ftp_proxy = http://proxy.yoyodyne.com:18023/
wget各种选项分类列表
* 启动
-V, --version 显示wget的版本后退出
-h, --help 打印语法帮助
-b, --background 启动后转入后台执行
-e, --execute=COMMAND 执行`.wgetrc'格式的命令,wgetrc格式参见/etc/wgetrc或~/.wgetrc
* 记录和输入文件
-o, --output-file=FILE 把记录写到FILE文件中
-a, --append-output=FILE 把记录追加到FILE文件中
-d, --debug 打印调试输出
-q, --quiet 安静模式(没有输出)
-v, --verbose 冗长模式(这是缺省设置)
-nv, --non-verbose 关掉冗长模式,但不是安静模式
-i, --input-file=FILE 下载在FILE文件中出现的URLs
-F, --force-html 把输入文件当作HTML格式文件对待
-B, --base=URL 将URL作为在-F -i参数指定的文件中出现的相对链接的前缀
--sslcertfile=FILE 可选客户端证书
--sslcertkey=KEYFILE 可选客户端证书的KEYFILE
--egd-file=FILE 指定EGD socket的文件名
* 下载
--bind-address=ADDRESS 指定本地使用地址(主机名或IP,当本地有多个IP或名字时使用)
-t, --tries=NUMBER 设定最大尝试链接次数(0 表示无限制).
-O --output-document=FILE 把文档写到FILE文件中
-nc, --no-clobber 不要覆盖存在的文件或使用.#前缀
-c, --continue 接着下载没下载完的文件
--progress=TYPE 设定进程条标记
-N, --timestamping 不要重新下载文件除非比本地文件新
-S, --server-response 打印服务器的回应
--spider 不下载任何东西
-T, --timeout=SECONDS 设定响应超时的秒数
-w, --wait=SECONDS 两次尝试之间间隔SECONDS秒
--waitretry=SECONDS 在重新链接之间等待1...SECONDS秒
--random-wait 在下载之间等待0...2*WAIT秒
-Y, --proxy=on/off 打开或关闭代理
-Q, --quota=NUMBER 设置下载的容量限制
--limit-rate=RATE 限定下载输率
* 目录
-nd --no-directories 不创建目录
-x, --force-directories 强制创建目录
-nH, --no-host-directories 不创建主机目录
-P, --directory-prefix=PREFIX 将文件保存到目录 PREFIX/...
--cut-dirs=NUMBER 忽略 NUMBER层远程目录
* HTTP 选项
--http-user=USER 设定HTTP用户名为 USER.
--http-passwd=PASS 设定http密码为 PASS.
-C, --cache=on/off 允许/不允许服务器端的数据缓存 (一般情况下允许).
-E, --html-extension 将所有text/html文档以.html扩展名保存
--ignore-length 忽略 `Content-Length'头域
--header=STRING 在headers中插入字符串 STRING
--proxy-user=USER 设定代理的用户名为 USER
--proxy-passwd=PASS 设定代理的密码为 PASS
--referer=URL 在HTTP请求中包含 `Referer: URL'头
-s, --save-headers 保存HTTP头到文件
-U, --user-agent=AGENT 设定代理的名称为 AGENT而不是 Wget/VERSION.
--no-http-keep-alive 关闭 HTTP活动链接 (永远链接).
--cookies=off 不使用 cookies.
--load-cookies=FILE 在开始会话前从文件 FILE中加载cookie
--save-cookies=FILE 在会话结束后将 cookies保存到 FILE文件中
* FTP 选项
-nr, --dont-remove-listing 不移走 `.listing'文件
-g, --glob=on/off 打开或关闭文件名的 globbing机制
--passive-ftp 使用被动传输模式 (缺省值).
--active-ftp 使用主动传输模式
--retr-symlinks 在递归的时候,将链接指向文件(而不是目录)
* 递归下载
-r, --recursive 递归下载--慎用!
-l, --level=NUMBER 最大递归深度 (inf 或 0 代表无穷).
--delete-after 在现在完毕后局部删除文件
-k, --convert-links 转换非相对链接为相对链接
-K, --backup-converted 在转换文件X之前,将之备份为 X.orig
-m, --mirror 等价于 -r -N -l inf -nr.
-p, --page-requisites 下载显示HTML文件的所有图片
* 递归下载中的包含和不包含(accept/reject)
-A, --accept=LIST 分号分隔的被接受扩展名的列表
-R, --reject=LIST 分号分隔的不被接受的扩展名的列表
-D, --domains=LIST 分号分隔的被接受域的列表
--exclude-domains=LIST 分号分隔的不被接受的域的列表
--follow-ftp 跟踪HTML文档中的FTP链接
--follow-tags=LIST 分号分隔的被跟踪的HTML标签的列表
-G, --ignore-tags=LIST 分号分隔的被忽略的HTML标签的列表
-H, --span-hosts 当递归时转到外部主机
-L, --relative 仅仅跟踪相对链接
-I, --include-directories=LIST 允许目录的列表
-X, --exclude-directories=LIST 不被包含目录的列表
-np, --no-parent 不要追溯到父目录
问题
在递归下载的时候,遇到目录中有中文的时候,wget创建的本地目录名会用URL编码规则处理。如"天网防火墙"会被存为"%CC%EC%CD%F8%B7%C0%BB%F0%C7%BD",这造成阅读上的困难。
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
所谓的自动下载是指,wget可以在用户退出系统的之后在后台执行。这意味这你可以登录系统,启动一个wget下载任务,然后退出系统,wget将在后台执行直到任务完成,相对于其它大部分浏览器在下载大量数据时需要用户一直的参与,这省去了极大的麻烦。
wget 可以跟踪HTML页面上的链接依次下载来创建远程服务器的本地版本,完全重建原始站点的目录结构。这又常被称作"递归下载"。在递归下载的时候,wget 遵循Robot Exclusion标准(/robots.txt). wget可以在下载的同时,将链接转换成指向本地文件,以方便离线浏览。
wget 非常稳定,它在带宽很窄的情况下和不稳定网络中有很强的适应性.如果是由于网络的原因下载失败,wget会不断的尝试,直到整个文件下载完毕。如果是服务器打断下载过程,它会再次联到服务器上从停止的地方继续下载。这对从那些限定了链接时间的服务器上下载大文件非常有用。
wget的常见用法
wget虽然功能强大,但是使用起来还是比较简单的,
基本的语法是:wget [参数列表] "URL" 用""引起来可以避免因URL中有特殊字符造成的下载出错。
下面就结合具体的例子来说明一下wget的用法。
引用
1、下载整个http或者ftp站点。
wget http://place.your.url/here
这个命令可以将http://place.your.url/here 首页下载下来。使用-x会强制建立服务器上一模一样的目录,如果使用-nd参数,那么服务器上下载的所有内容都会加到本地当前目录。
wget -r http://place.your.url/here
这个命令会按照递归的方法,下载服务器上所有的目录和文件,实质就是下载整个网站。这个命令一定要小心使用,因为在下载的时候,被下载网站指向的所有地址同样会被下载,因此,如果这个网站引用了其他网站,那么被引用的网站也会被下载下来!基于这个原因,这个参数不常用。可以用-l number参数来指定下载的层次。例如只下载两层,那么使用-l 2。
要是您想制作镜像站点,那么可以使用-m参数,例如:wget -m http://place.your.url/here
这时wget会自动判断合适的参数来制作镜像站点。此时,wget会登录到服务器上,读入robots.txt并按robots.txt的规定来执行。
wget http://place.your.url/here
这个命令可以将http://place.your.url/here 首页下载下来。使用-x会强制建立服务器上一模一样的目录,如果使用-nd参数,那么服务器上下载的所有内容都会加到本地当前目录。
wget -r http://place.your.url/here
这个命令会按照递归的方法,下载服务器上所有的目录和文件,实质就是下载整个网站。这个命令一定要小心使用,因为在下载的时候,被下载网站指向的所有地址同样会被下载,因此,如果这个网站引用了其他网站,那么被引用的网站也会被下载下来!基于这个原因,这个参数不常用。可以用-l number参数来指定下载的层次。例如只下载两层,那么使用-l 2。
要是您想制作镜像站点,那么可以使用-m参数,例如:wget -m http://place.your.url/here
这时wget会自动判断合适的参数来制作镜像站点。此时,wget会登录到服务器上,读入robots.txt并按robots.txt的规定来执行。
引用
2、断点续传。
当文件特别大或者网络特别慢的时候,往往一个文件还没有下载完,连接就已经被切断,此时就需要断点续传。wget的断点续传是自动的,只需要使用-c参数,例如:
wget -c http://the.url.of/incomplete/file
使用断点续传要求服务器支持断点续传。-t参数表示重试次数,例如需要重试100次,那么就写-t 100,如果设成-t 0,那么表示无穷次重试,直到连接成功。-T参数表示超时等待时间,例如-T 120,表示等待120秒连接不上就算超时。
当文件特别大或者网络特别慢的时候,往往一个文件还没有下载完,连接就已经被切断,此时就需要断点续传。wget的断点续传是自动的,只需要使用-c参数,例如:
wget -c http://the.url.of/incomplete/file
使用断点续传要求服务器支持断点续传。-t参数表示重试次数,例如需要重试100次,那么就写-t 100,如果设成-t 0,那么表示无穷次重试,直到连接成功。-T参数表示超时等待时间,例如-T 120,表示等待120秒连接不上就算超时。
引用
3、批量下载。
如果有多个文件需要下载,那么可以生成一个文件,把每个文件的URL写一行,例如生成文件download.txt,然后用命令:wget -i download.txt
这样就会把download.txt里面列出的每个URL都下载下来。(如果列的是文件就下载文件,如果列的是网站,那么下载首页)
如果有多个文件需要下载,那么可以生成一个文件,把每个文件的URL写一行,例如生成文件download.txt,然后用命令:wget -i download.txt
这样就会把download.txt里面列出的每个URL都下载下来。(如果列的是文件就下载文件,如果列的是网站,那么下载首页)
引用
4、选择性的下载。
可以指定让wget只下载一类文件,或者不下载什么文件。例如:
wget -m --reject=gif http://target.web.site/subdirectory
表示下载http://target.web.site/subdirectory,但是忽略gif文件。--accept=LIST 可以接受的文件类型,--reject=LIST拒绝接受的文件类型。
可以指定让wget只下载一类文件,或者不下载什么文件。例如:
wget -m --reject=gif http://target.web.site/subdirectory
表示下载http://target.web.site/subdirectory,但是忽略gif文件。--accept=LIST 可以接受的文件类型,--reject=LIST拒绝接受的文件类型。
引用
5、密码和认证。
wget只能处理利用用户名/密码方式限制访问的网站,可以利用两个参数:
--http-user=USER设置HTTP用户
--http-passwd=PASS设置HTTP密码
对于需要证书做认证的网站,就只能利用其他下载工具了,例如curl。
wget只能处理利用用户名/密码方式限制访问的网站,可以利用两个参数:
--http-user=USER设置HTTP用户
--http-passwd=PASS设置HTTP密码
对于需要证书做认证的网站,就只能利用其他下载工具了,例如curl。
引用
6、利用代理服务器进行下载。
如果用户的网络需要经过代理服务器,那么可以让wget通过代理服务器进行文件的下载。此时需要在当前用户的目录下创建一个.wgetrc文件。文件中可以设置代理服务器:
http-proxy = 111.111.111.111:8080
ftp-proxy = 111.111.111.111:8080
分别表示http的代理服务器和ftp的代理服务器。如果代理服务器需要密码则使用:
--proxy-user=USER设置代理用户
--proxy-passwd=PASS设置代理密码
这两个参数。
使用参数--proxy=on/off 使用或者关闭代理。
如果用户的网络需要经过代理服务器,那么可以让wget通过代理服务器进行文件的下载。此时需要在当前用户的目录下创建一个.wgetrc文件。文件中可以设置代理服务器:
http-proxy = 111.111.111.111:8080
ftp-proxy = 111.111.111.111:8080
分别表示http的代理服务器和ftp的代理服务器。如果代理服务器需要密码则使用:
--proxy-user=USER设置代理用户
--proxy-passwd=PASS设置代理密码
这两个参数。
使用参数--proxy=on/off 使用或者关闭代理。
wget还有很多有用的功能,需要用户去挖掘。
wget的使用格式
Usage: wget [OPTION]... [URL]...
* 用wget做站点镜像:
wget -r -p -np -k http://dsec.pku.edu.cn/~usr_name/
# 或者
wget -m http://dsec.pku.edu.cn/~usr_name/
* 在不稳定的网络上下载一个部分下载的文件,以及在空闲时段下载
wget -t 0 -w 31 -c http://dsec.pku.edu.cn/BBC.avi -o down.log &
# 或者从filelist读入要下载的文件列表
wget -t 0 -w 31 -c -B ftp://dsec.pku.edu.cn/linuxsoft -i filelist.txt -o down.log &
上面的代码还可以用来在网络比较空闲的时段进行下载。我的用法是:在mozilla中将不方便当时下载的URL链接拷贝到内存中然后粘贴到文件filelist.txt中,在晚上要出去系统前执行上面代码的第二条。
* 使用代理下载
wget -Y on -p -k https://sourceforge.net/projects/wvware/
代理可以在环境变量或wgetrc文件中设定
# 在环境变量中设定代理
export PROXY=http://211.90.168.94:8080/
# 在~/.wgetrc中设定代理
http_proxy = http://proxy.yoyodyne.com:18023/
ftp_proxy = http://proxy.yoyodyne.com:18023/
wget各种选项分类列表
* 启动
-V, --version 显示wget的版本后退出
-h, --help 打印语法帮助
-b, --background 启动后转入后台执行
-e, --execute=COMMAND 执行`.wgetrc'格式的命令,wgetrc格式参见/etc/wgetrc或~/.wgetrc
* 记录和输入文件
-o, --output-file=FILE 把记录写到FILE文件中
-a, --append-output=FILE 把记录追加到FILE文件中
-d, --debug 打印调试输出
-q, --quiet 安静模式(没有输出)
-v, --verbose 冗长模式(这是缺省设置)
-nv, --non-verbose 关掉冗长模式,但不是安静模式
-i, --input-file=FILE 下载在FILE文件中出现的URLs
-F, --force-html 把输入文件当作HTML格式文件对待
-B, --base=URL 将URL作为在-F -i参数指定的文件中出现的相对链接的前缀
--sslcertfile=FILE 可选客户端证书
--sslcertkey=KEYFILE 可选客户端证书的KEYFILE
--egd-file=FILE 指定EGD socket的文件名
* 下载
--bind-address=ADDRESS 指定本地使用地址(主机名或IP,当本地有多个IP或名字时使用)
-t, --tries=NUMBER 设定最大尝试链接次数(0 表示无限制).
-O --output-document=FILE 把文档写到FILE文件中
-nc, --no-clobber 不要覆盖存在的文件或使用.#前缀
-c, --continue 接着下载没下载完的文件
--progress=TYPE 设定进程条标记
-N, --timestamping 不要重新下载文件除非比本地文件新
-S, --server-response 打印服务器的回应
--spider 不下载任何东西
-T, --timeout=SECONDS 设定响应超时的秒数
-w, --wait=SECONDS 两次尝试之间间隔SECONDS秒
--waitretry=SECONDS 在重新链接之间等待1...SECONDS秒
--random-wait 在下载之间等待0...2*WAIT秒
-Y, --proxy=on/off 打开或关闭代理
-Q, --quota=NUMBER 设置下载的容量限制
--limit-rate=RATE 限定下载输率
* 目录
-nd --no-directories 不创建目录
-x, --force-directories 强制创建目录
-nH, --no-host-directories 不创建主机目录
-P, --directory-prefix=PREFIX 将文件保存到目录 PREFIX/...
--cut-dirs=NUMBER 忽略 NUMBER层远程目录
* HTTP 选项
--http-user=USER 设定HTTP用户名为 USER.
--http-passwd=PASS 设定http密码为 PASS.
-C, --cache=on/off 允许/不允许服务器端的数据缓存 (一般情况下允许).
-E, --html-extension 将所有text/html文档以.html扩展名保存
--ignore-length 忽略 `Content-Length'头域
--header=STRING 在headers中插入字符串 STRING
--proxy-user=USER 设定代理的用户名为 USER
--proxy-passwd=PASS 设定代理的密码为 PASS
--referer=URL 在HTTP请求中包含 `Referer: URL'头
-s, --save-headers 保存HTTP头到文件
-U, --user-agent=AGENT 设定代理的名称为 AGENT而不是 Wget/VERSION.
--no-http-keep-alive 关闭 HTTP活动链接 (永远链接).
--cookies=off 不使用 cookies.
--load-cookies=FILE 在开始会话前从文件 FILE中加载cookie
--save-cookies=FILE 在会话结束后将 cookies保存到 FILE文件中
* FTP 选项
-nr, --dont-remove-listing 不移走 `.listing'文件
-g, --glob=on/off 打开或关闭文件名的 globbing机制
--passive-ftp 使用被动传输模式 (缺省值).
--active-ftp 使用主动传输模式
--retr-symlinks 在递归的时候,将链接指向文件(而不是目录)
* 递归下载
-r, --recursive 递归下载--慎用!
-l, --level=NUMBER 最大递归深度 (inf 或 0 代表无穷).
--delete-after 在现在完毕后局部删除文件
-k, --convert-links 转换非相对链接为相对链接
-K, --backup-converted 在转换文件X之前,将之备份为 X.orig
-m, --mirror 等价于 -r -N -l inf -nr.
-p, --page-requisites 下载显示HTML文件的所有图片
* 递归下载中的包含和不包含(accept/reject)
-A, --accept=LIST 分号分隔的被接受扩展名的列表
-R, --reject=LIST 分号分隔的不被接受的扩展名的列表
-D, --domains=LIST 分号分隔的被接受域的列表
--exclude-domains=LIST 分号分隔的不被接受的域的列表
--follow-ftp 跟踪HTML文档中的FTP链接
--follow-tags=LIST 分号分隔的被跟踪的HTML标签的列表
-G, --ignore-tags=LIST 分号分隔的被忽略的HTML标签的列表
-H, --span-hosts 当递归时转到外部主机
-L, --relative 仅仅跟踪相对链接
-I, --include-directories=LIST 允许目录的列表
-X, --exclude-directories=LIST 不被包含目录的列表
-np, --no-parent 不要追溯到父目录
问题
在递归下载的时候,遇到目录中有中文的时候,wget创建的本地目录名会用URL编码规则处理。如"天网防火墙"会被存为"%CC%EC%CD%F8%B7%C0%BB%F0%C7%BD",这造成阅读上的困难。
引用
wget -r -N -l 3 -np -p -b -k http://www.jobzone.cn
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
FreeBSD的默认文件系统是ufs,如果要对其它文件系统的支持,就要在内核中增加相应的文件系统,然后重新编译内核,常用的MSDOS,CD9660在GENERIC内核(系统默认内核)中已有,而Linux的ext2fs没有,为了对ext2fs的支持,在内核中增加一行:
options "EXT2FS"
重新编译内核,重启机器。
可用fdisk /dev/wd0查看硬盘wd0的slice情况,对于FreeBSD的slice,还可用disklabel -r /dev/wd0s1命令来查看硬盘wd0的第一个slice的情况。进入/dev,查看硬盘设备,如还没有相应的,可用sh MAKEDEV建相应设备
这些工作之后,就可用mount命令了,例如:
/mnt为目录,该目录必须存在
1.mount FAT/FAT32分区:(C盘为例)
2.mout Windows的扩展分区(FAT/FAT32):
3.mount NTFS分区:(C盘为例)
mount -t ntfs /dev/ad0s1 /mnt
或
mount_ntfs /dev/ad0s1 /mnt
[注意]1.chinese/gbfs 的 ntfs 似乎有问题,不建议玩家级用户使用
注意2.:要让mount上的windows 分区(或CD-ROM)显示中文,需要升级你的ports,再安装gbfs:
#cd /usr/ports/chinese/gbfs
#make install clean
然后编译内核,注释掉options CD9660
options MSDOS
注意3.在5.1-current上不用安装gbfs,用:
mount_msdosfs -L zh_CN.GB18030 /dev/ad0sX /mnt
命令就可以支持FAT32分区上的中文文件名,当然,locale可以不用18030,zh_CN.eucCN, zh_CN.GBK都可以!
4.mount Linux Ext2fs/Ext3fs:
5.mount 普通数据光盘:
6.mount ISO 文件
在5.x中如下
mdconfig -a -t vnode -f abc.iso -u 1
mount_cd9660 /dev/md1 /cdrom
4.8的版本
vnconfig /dev/vn0 /home/xiaoche/a.iso
mount -t cd9660 /dev/vn0 /mnt
umount /mnt
vnconfig -u /dev/vn0
7.mount CD、VCD、DVD
播放CD、VCD、DVD不用先mount上。
如果你一定要mount上,可以这样:#mount _cd9660 -s 0 /dev/acd0 /cdrom
8.mount 软盘:
1.Format:
# /usr/sbin/fdformat -f 1440 /dev/fd0
2. Run disklabel:
# /sbin/disklabel -B -r -w /dev/fd0 fd1440
3.Create New FS:
# /sbin/newfs_msdos /dev/fd0
4.Mount & Use
#mount_msdosfs /dev/fd0 /mnt
9.mount usb
10.mount ZIP软盘:
说了这么多,就是没说在freeBSD系统多块硬盘怎么挂载,现在请看下面的:
希望上面的知识能够让大家更加了解freeBSD。有什么疑问请加QQ:29011218或MSN:onenight11@hotmail.com交流。
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
options "EXT2FS"
重新编译内核,重启机器。
可用fdisk /dev/wd0查看硬盘wd0的slice情况,对于FreeBSD的slice,还可用disklabel -r /dev/wd0s1命令来查看硬盘wd0的第一个slice的情况。进入/dev,查看硬盘设备,如还没有相应的,可用sh MAKEDEV建相应设备
这些工作之后,就可用mount命令了,例如:
/mnt为目录,该目录必须存在
1.mount FAT/FAT32分区:(C盘为例)
引用
mount -t msdos /dev/ad0s1 /mnt
或
mount_msdos /dev/ad0s1 /mnt for 4.x
mount_msdosfs /dev/ad0s1 /mnt for 5.x
或
mount_msdos /dev/ad0s1 /mnt for 4.x
mount_msdosfs /dev/ad0s1 /mnt for 5.x
2.mout Windows的扩展分区(FAT/FAT32):
引用
命令和1一样,只是要记住:扩展分区从s5开始,例如mount D盘,可用:
mount -t msdos /dev/ad0s5 /mnt
mount_msdos /dev/ad0s5 /mnt for 4.x
mount_msdosfs /dev/ad0s5 /mnt for 5.x
mount -t msdos /dev/ad0s5 /mnt
mount_msdos /dev/ad0s5 /mnt for 4.x
mount_msdosfs /dev/ad0s5 /mnt for 5.x
3.mount NTFS分区:(C盘为例)
引用
mount -t ntfs /dev/ad0s1 /mnt
或
mount_ntfs /dev/ad0s1 /mnt
[注意]1.chinese/gbfs 的 ntfs 似乎有问题,不建议玩家级用户使用
注意2.:要让mount上的windows 分区(或CD-ROM)显示中文,需要升级你的ports,再安装gbfs:
#cd /usr/ports/chinese/gbfs
#make install clean
然后编译内核,注释掉options CD9660
options MSDOS
注意3.在5.1-current上不用安装gbfs,用:
mount_msdosfs -L zh_CN.GB18030 /dev/ad0sX /mnt
命令就可以支持FAT32分区上的中文文件名,当然,locale可以不用18030,zh_CN.eucCN, zh_CN.GBK都可以!
4.mount Linux Ext2fs/Ext3fs:
引用
在内核里面加入options EXT2FS,编译内核。
mount 的时候用mount_ext2fs 命令即可,ext3fs的mount也用mount_ext2fs
mount 的时候用mount_ext2fs 命令即可,ext3fs的mount也用mount_ext2fs
5.mount 普通数据光盘:
引用
mount_cd9660 /dev/acd0 /cdrom
6.mount ISO 文件
引用
在5.x中如下
mdconfig -a -t vnode -f abc.iso -u 1
mount_cd9660 /dev/md1 /cdrom
4.8的版本
vnconfig /dev/vn0 /home/xiaoche/a.iso
mount -t cd9660 /dev/vn0 /mnt
umount /mnt
vnconfig -u /dev/vn0
7.mount CD、VCD、DVD
引用
播放CD、VCD、DVD不用先mount上。
如果你一定要mount上,可以这样:#mount _cd9660 -s 0 /dev/acd0 /cdrom
8.mount 软盘:
引用
1.Format:
# /usr/sbin/fdformat -f 1440 /dev/fd0
2. Run disklabel:
# /sbin/disklabel -B -r -w /dev/fd0 fd1440
3.Create New FS:
# /sbin/newfs_msdos /dev/fd0
4.Mount & Use
#mount_msdosfs /dev/fd0 /mnt
9.mount usb
引用
确保内核中有如下项
device scbus
device da
device cd
在GENERIC中默认都有,如果没有,请编译内核。
大多数U盘用的是FAT 文件系统,所以用
mount -t msdos /dev/da0 /mnt
挂载
device scbus
device da
device cd
在GENERIC中默认都有,如果没有,请编译内核。
大多数U盘用的是FAT 文件系统,所以用
mount -t msdos /dev/da0 /mnt
挂载
10.mount ZIP软盘:
引用
#mount_msdosfs /dev/afd0s4 /mnt/zip
说了这么多,就是没说在freeBSD系统多块硬盘怎么挂载,现在请看下面的:
引用
1.用systinstall 分区,测试,安装最小系统(已经格式化)
2.newfs /dev/ad1s1 格式化命令(第一步未格式化才需执行)
3.mount /dev/ad1s1 /disk1/ (挂载硬盘1到/disk1/目录下,该目录必须存在)
4.vi /etc/fstab (加入/dev/ad1s1 /disk1 ufs rw 1 1,这样开机重启就可以自动挂载了)
2.newfs /dev/ad1s1 格式化命令(第一步未格式化才需执行)
3.mount /dev/ad1s1 /disk1/ (挂载硬盘1到/disk1/目录下,该目录必须存在)
4.vi /etc/fstab (加入/dev/ad1s1 /disk1 ufs rw 1 1,这样开机重启就可以自动挂载了)
希望上面的知识能够让大家更加了解freeBSD。有什么疑问请加QQ:29011218或MSN:onenight11@hotmail.com交流。
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
一、驱动类型 驱动设备名
二、分区的问题
FreeBSD的硬盘分割区域称为slice(片段或部分),一个硬盘最多可有四个FreeBSD的slice,FreeBSD的开机区必须在这些slice其中之一。每一个FreeBSD的slice有8个partition,分别称为a,b,c,d,e,f,g,h,传统上a,b,c,d分区有特殊的意义,a表示root分区,b表示swap分区,c表示整个slice,d表示整个硬盘,从FreeBSD-2.0.5 Release开始,FreeBSD发展了新的slice概念,只有c内定位整个slice,其它都可自由使用,但一般还是遵循传统观念,即a:root,b:swap,efgh:其它使用。
对于非FreeBSD的slice,没有a,b,c等的partition概念。对于DOS扩展分区的逻辑公区,是从s5开始的,例如,对于3.4-release中,第一个IDE硬盘的第一个扩展区的第一个逻辑分区是wd0s5,第二个逻辑分区是wd0s6。
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
引用
IDE hard drives --- ad in 4.0-RELEASE, wd before 4.0-RELEASE.
IDE CDROM drives --- acd from 3.1-RELEASE, wcd before 4.0-RELEASE.
SCSI hard drives --- da from 3.0-RELEASE, sd before 3.0-RELEASE.
SCSI CDROM drives --- cd
Assorted non-standard CDROM drives--- mcd for Mitsumi CD-ROM, scd for Sony CD-ROM,
matcd for Matsushita/Panasonic CD-ROM
Floppy drives --- fd
SCSI tape drives --- sa from 3.0-RELEASE, st before 3.0-RELEASE.
IDE tape drives --- ast from 4.0-RELEASE, wst before 4.0-RELEASE.
Flash drives --- fla for DiskOnChip Flash device from 3.3-RELEASE.
RAID drives --- myxd for Mylex, amrd for AMI MegaRAID, idad for Compaq
Smart RAID. from 4.0-RELEASE. id between 3.2-RELEASE and 4.0-RELEASE.
硬盘的编号从0开始,例如在3.4-release中,第一个IDE硬盘是wd0。
IDE CDROM drives --- acd from 3.1-RELEASE, wcd before 4.0-RELEASE.
SCSI hard drives --- da from 3.0-RELEASE, sd before 3.0-RELEASE.
SCSI CDROM drives --- cd
Assorted non-standard CDROM drives--- mcd for Mitsumi CD-ROM, scd for Sony CD-ROM,
matcd for Matsushita/Panasonic CD-ROM
Floppy drives --- fd
SCSI tape drives --- sa from 3.0-RELEASE, st before 3.0-RELEASE.
IDE tape drives --- ast from 4.0-RELEASE, wst before 4.0-RELEASE.
Flash drives --- fla for DiskOnChip Flash device from 3.3-RELEASE.
RAID drives --- myxd for Mylex, amrd for AMI MegaRAID, idad for Compaq
Smart RAID. from 4.0-RELEASE. id between 3.2-RELEASE and 4.0-RELEASE.
硬盘的编号从0开始,例如在3.4-release中,第一个IDE硬盘是wd0。
二、分区的问题
FreeBSD的硬盘分割区域称为slice(片段或部分),一个硬盘最多可有四个FreeBSD的slice,FreeBSD的开机区必须在这些slice其中之一。每一个FreeBSD的slice有8个partition,分别称为a,b,c,d,e,f,g,h,传统上a,b,c,d分区有特殊的意义,a表示root分区,b表示swap分区,c表示整个slice,d表示整个硬盘,从FreeBSD-2.0.5 Release开始,FreeBSD发展了新的slice概念,只有c内定位整个slice,其它都可自由使用,但一般还是遵循传统观念,即a:root,b:swap,efgh:其它使用。
对于非FreeBSD的slice,没有a,b,c等的partition概念。对于DOS扩展分区的逻辑公区,是从s5开始的,例如,对于3.4-release中,第一个IDE硬盘的第一个扩展区的第一个逻辑分区是wd0s5,第二个逻辑分区是wd0s6。
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
长期以来,Windows网络管理人员使用Edit,记事本或者Wordpad来编辑文本文件和手写文件。对UNIX操作系统而言,大多数UNIX系统都具有各自类型的编辑器,但是实际使用的工具不尽相同,这取决于使用的UNIX系统。当前,一些编辑器甚至已经成为微软Word强有力的竞争对手,比如Sun Microsystems。但是,所有UNIX操作系统机器上都安装有vi可视化编辑器。一旦掌握vi的使用技巧,你就可以在所有的UNIX操作系统(包括Linux操作系统)中随意编辑文件。
Vi为何物?
乍一看,vi除了全屏幕可视外就没有什么可值得称道。但是, 她却是一个功能非常强大的编辑器,而且可以满足你需要的任何操作。vi可以在操作的时候让你编辑和浏览整个文件。以前的许多编辑器,比如ed都是行编辑器,即每次只能编辑和浏览一行文字。因此相比于过去的UNIX编辑器,vi更加便于整个文件的浏览。
很多UNIX操作系统都集中多个不同的命令行功能,比如nroff和troff等文件处理工具。与微软的Word一样,这些命令行功能可以编辑出不同格式和风格的文件。我亲自使用了这些工具来编写我的毕业论文,感觉非常的方便。
在机器上安装vi无需特别的安装路径,对此你无需太多担心。当安装系统的时候,vi自动会出现。因为系统管理员需要使用vi处理很多工作,包括创建系统文本等。Redhat的Linux在系统中提供了安装特定编辑器的选择,但是在UNIX操作系统不安装vi的情况相当少见
Vi使用与操作
在介绍如何使用vi之前,了解vi具有两种基本模式是很重要。这两种基本模式为输入模式和指令模式。输入模式为输入命令,文本就会显示在屏幕上;而指令模式为输入命令就执行命令,而不会显示文字。理解指令模式最简单方式就是想象平时剪切、复制以及粘贴数据时所发生的情况。
在默认状态下,vi以指令模式下启动,因此你输入命令时不会显示文字,除非你输入命令切换至输入模式。大多数vi命令不会屏幕上显示任何东西,你只需要知道它们的工作过程就足够了。使用[Esc]键可以在输入模式和指令模式之间切换。如果你已经处于指令模式中,使用[Esc]将会告诉vi,你已经输入命令并将要执行命令。如果你没有输入任何命令,在指令模式中按下[Esc]键将中断操作。
现在我已经介绍了vi的基本操作,你可以动手试用一下。首先,在你的工作站打开一个终端窗口,你只需在$提示中输入vi然后按回车键就可以启动vi编辑器。
接着,你将看到弹出一个页面左下角有一个~符号的空白文件。这一符号不容易看到,但是你看到的这些~符号正是表示处于文件的底部。当对文件保存之后,这些符号就不会显示出来。 若要编辑某个文件或者为一空白文件命名,你可输入vi filename。vi filename可以是一个已经存在的文件名或者是一个给新文件指定的名称。
通用输入模式
一旦进入编辑文档,除了使用[Esc]切换方法,还有其它很多方法使vi进入到输入模式。很多其它的方法都包含使用一个vi指令。这些指令可以立即让vi进入输入模式,由此输入的字符立即以文字出现在文档中。常用的指令为:
i 这是一个输入命令,即从光标所在位置前面开始插入文字,光标后的文字随新增文字向向移动。 如果是一个空白文档,文字将会输入在文档的左上角。
I 在行命令开始处的输入模式,即在当前行的开始处输入文字。与Word中的按下键后输入文字类似。
a 这是一个新增命令,即从光标所在位置后面开始新增文字,光标后的资料随新增文字向后移动。
A 这是一个新增到行命令的操作,即从光标所在行最后面的地方开始新增文字。这与Word中的按下键后输入文字类似。
o 这是一个命令之下的打开行命令,即在光标所在行下面新增一行并进入输入模式。
O 这是一个命令之上的打开命令,即在光标所在行上方新增一行并进入输入模式。
编辑之后使用以上任一命令,将会返回到指令模式。
光标移动指令
接下来需要学习的是vi中的浏览命令。以指令模式在文档中移动,可以使用以下的命令:
h:将一个文字移动到左边
j:往下移动一个文字
k: 往上移动一个文字
l: 将一个文字移动到右边
在鼠标与GUI的环境中,这些移动命令看似有些过时,但是它们都被包含于所有vi版本就广泛应用。很多时候,光标号,上光标,下光标,左光标,右光标都会起到作用,但是操作者应该将termcap与terminfo属性包含在这些命令之中。
以下的其它移动指令也可大有帮助:
[Ctrl]f 向下移动一页指令。这将使得光标在文本中向下移动一页。
[Ctrl]b 向后移动一页指令。这将使得光标在文本中向后移动一页。
[Ctrl]u 向下移动半页指令。这将使得光标在文本中向下移动半页。
^ 行命令开始处。光标将会移动到行的开始处。
$ 行命令结束处。光标将会移动到行的结束处。
w 移动到上一个文字的开始。
b 移动到下一个文字的开始。
e 文字末端指令。
G 移动到文件的末端。
常规功能
在一般的文本编辑器中,所有的功能,比如删除,更改,剪切,复制,粘贴,以及搜索/替代等,都可以在vi中找到。很多指令都可以将编辑状态进入输入模式,而又可以使用[Esc]来终止。常规使用的编辑指令包括:
x:删除字符命令,即删除光标所在字符。
dw:删除文字命令,即删除光标处的文字。
dd:删除行命令,即删除光标所在的行。
D:删除到行末端,即删除从光标所在位置到行末端的所有文本。
cw:改变文字命令,即光标所有位置的文字将随着输入文字而改变,至到按下[Esc]。
r:替代字符命令,即光标所在位置的字符将被输入的字符替代,至到按下[Esc]。
R:替代多行字符命令,即光标所在位置到右边所有的字符将被输入的字符替代,至到按下[Esc]。
绝大多数这些指令都可以通过组合而提高其功能。
例如,如果你输入2dd,vi将删除两行文本。
剪切与粘贴等操作
与其它很多编辑器一样,你可以在文档中使用剪切与粘贴文本。以下命令是可以使用的最为简单的剪切与粘贴操作。
yy 复制行命令。光标所有行的文本将被复制到类似剪切板的缓冲器。注意到可以使用多个复制命令更改这一命令以将多行文字剪切到缓冲器。
yl 复制字符命令。光标所有行的字符将被复制到类似剪切板的缓冲器。可以使用多个复制命令更改这一命令以将多行字符剪切到缓冲器。
p 后放置命令。在当前光标位置之后放置或粘贴缓冲器的内容。对于复制行命令,缓冲器的内容将被粘贴在当前行之后。对于复制字符行命令,缓冲器内容将被粘贴在光标的右边。
P 前放置命令。在当前光标位置之前放置或粘贴缓冲器的内容。对于复制行命令,缓冲器的内容将被粘贴在当前行之前。对于复制字符行命令,缓冲器内容将被粘贴在光标的左边。
使用复制和放置指令时,你也可以字符指令而使用多个缓冲器或剪切板。这些字符可为a-z,并且只能是小写字母。例如,ayy将当前行内容复制到缓冲器A,ap命令将缓冲器的内容粘贴在当前行之前。
Vi中最为重要的命令要算undo指令。这一命令十分简单:只需要按下u。按下u键就可以撤消最近使用的一次指令。 与undo命令类似的是redo命令。按下句号键(.)将会重新键入最近的指令。例如,如果你使用cw来改变一个文字,你可以查找这一文字然后使用句号.来这一文字。
其它两个重要的命令为search命令。为了在文档中向前查找,可键入/text,text即为你查找的内容。重要的是一定注意,只有输入内容完全的匹配,你才可以查找到。Vi不支持混合查询或者模糊查询。对于向后查找,可键入?text,text即为查找的内容。
编辑指令
在指令模式中,很多组命令都可以前缀:。与以上提及的命令不一样,一旦输入一个冒号,所有指令都出现在屏幕的左下角,并可以在执行之前编辑。以下是常用的重要的:指令。 :w 编写文件命令。如果你输入:w然后回车,当前文件将被写入硬盘。如果使用的是一个空白文档,将会出现“没有当前的文件名”的消息。可以使用:w文件名将一个空白文档或当前文档写入到另一文件。
:w!或:w文件名 覆盖文件命令。如果输入:w!然后回车,文件将会被当前新输入的名称而覆盖。这可用于文件的覆盖。
:q 退出命令。如果正常保持,输入:q将会终止整个操作。
:q! 退出而不需要保持命令。在不需要保存文件的情况下退出。
:%s/find_text/replace_text/
查询与替代命令
正如上面提及一样,可以改变查询命令为一个查询与替代命令。使用:%s命令可以告诉vi查询文档中所有行。/find_text命令与以上的查询命令类似,当其后缀/replace_text/,时,/find_text操作结果的第一行将会被替代。为了将/find_text所有内容被替代,可以增加一个g(全局),比如:%s/find_text/replace_text/g。
你不要只使用单一的指令。你可以将多个指令结合使用。例如,:wq!将会保存文件到硬盘并退出vi而返回到指令状态。 Vi=包含全部(Very involved) 以上提及的内容只是vi功能的一小部分。你可以一起执行指令串,以标记方式复制而粘贴文本,或者使用sed指令。你还可以将shell script的输出或其它指令插入到你的文档中。 以上涉及到的例子和指令将可以带你进入vi的大门。很多vi使用者在操作时都会记住一些命令。从其它使用vi的人可以学会更多的vi指令,而此时你或许惊叹vi的强大。然而,你应该记住一点:经常地使用:a指令,因为vi没有提供自动后台文档保存功能。
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
Vi为何物?
乍一看,vi除了全屏幕可视外就没有什么可值得称道。但是, 她却是一个功能非常强大的编辑器,而且可以满足你需要的任何操作。vi可以在操作的时候让你编辑和浏览整个文件。以前的许多编辑器,比如ed都是行编辑器,即每次只能编辑和浏览一行文字。因此相比于过去的UNIX编辑器,vi更加便于整个文件的浏览。
很多UNIX操作系统都集中多个不同的命令行功能,比如nroff和troff等文件处理工具。与微软的Word一样,这些命令行功能可以编辑出不同格式和风格的文件。我亲自使用了这些工具来编写我的毕业论文,感觉非常的方便。
在机器上安装vi无需特别的安装路径,对此你无需太多担心。当安装系统的时候,vi自动会出现。因为系统管理员需要使用vi处理很多工作,包括创建系统文本等。Redhat的Linux在系统中提供了安装特定编辑器的选择,但是在UNIX操作系统不安装vi的情况相当少见
Vi使用与操作
在介绍如何使用vi之前,了解vi具有两种基本模式是很重要。这两种基本模式为输入模式和指令模式。输入模式为输入命令,文本就会显示在屏幕上;而指令模式为输入命令就执行命令,而不会显示文字。理解指令模式最简单方式就是想象平时剪切、复制以及粘贴数据时所发生的情况。
在默认状态下,vi以指令模式下启动,因此你输入命令时不会显示文字,除非你输入命令切换至输入模式。大多数vi命令不会屏幕上显示任何东西,你只需要知道它们的工作过程就足够了。使用[Esc]键可以在输入模式和指令模式之间切换。如果你已经处于指令模式中,使用[Esc]将会告诉vi,你已经输入命令并将要执行命令。如果你没有输入任何命令,在指令模式中按下[Esc]键将中断操作。
现在我已经介绍了vi的基本操作,你可以动手试用一下。首先,在你的工作站打开一个终端窗口,你只需在$提示中输入vi然后按回车键就可以启动vi编辑器。
接着,你将看到弹出一个页面左下角有一个~符号的空白文件。这一符号不容易看到,但是你看到的这些~符号正是表示处于文件的底部。当对文件保存之后,这些符号就不会显示出来。 若要编辑某个文件或者为一空白文件命名,你可输入vi filename。vi filename可以是一个已经存在的文件名或者是一个给新文件指定的名称。
通用输入模式
一旦进入编辑文档,除了使用[Esc]切换方法,还有其它很多方法使vi进入到输入模式。很多其它的方法都包含使用一个vi指令。这些指令可以立即让vi进入输入模式,由此输入的字符立即以文字出现在文档中。常用的指令为:
i 这是一个输入命令,即从光标所在位置前面开始插入文字,光标后的文字随新增文字向向移动。 如果是一个空白文档,文字将会输入在文档的左上角。
I 在行命令开始处的输入模式,即在当前行的开始处输入文字。与Word中的按下键后输入文字类似。
a 这是一个新增命令,即从光标所在位置后面开始新增文字,光标后的资料随新增文字向后移动。
A 这是一个新增到行命令的操作,即从光标所在行最后面的地方开始新增文字。这与Word中的按下键后输入文字类似。
o 这是一个命令之下的打开行命令,即在光标所在行下面新增一行并进入输入模式。
O 这是一个命令之上的打开命令,即在光标所在行上方新增一行并进入输入模式。
编辑之后使用以上任一命令,将会返回到指令模式。
光标移动指令
接下来需要学习的是vi中的浏览命令。以指令模式在文档中移动,可以使用以下的命令:
h:将一个文字移动到左边
j:往下移动一个文字
k: 往上移动一个文字
l: 将一个文字移动到右边
在鼠标与GUI的环境中,这些移动命令看似有些过时,但是它们都被包含于所有vi版本就广泛应用。很多时候,光标号,上光标,下光标,左光标,右光标都会起到作用,但是操作者应该将termcap与terminfo属性包含在这些命令之中。
以下的其它移动指令也可大有帮助:
[Ctrl]f 向下移动一页指令。这将使得光标在文本中向下移动一页。
[Ctrl]b 向后移动一页指令。这将使得光标在文本中向后移动一页。
[Ctrl]u 向下移动半页指令。这将使得光标在文本中向下移动半页。
^ 行命令开始处。光标将会移动到行的开始处。
$ 行命令结束处。光标将会移动到行的结束处。
w 移动到上一个文字的开始。
b 移动到下一个文字的开始。
e 文字末端指令。
G 移动到文件的末端。
常规功能
在一般的文本编辑器中,所有的功能,比如删除,更改,剪切,复制,粘贴,以及搜索/替代等,都可以在vi中找到。很多指令都可以将编辑状态进入输入模式,而又可以使用[Esc]来终止。常规使用的编辑指令包括:
x:删除字符命令,即删除光标所在字符。
dw:删除文字命令,即删除光标处的文字。
dd:删除行命令,即删除光标所在的行。
D:删除到行末端,即删除从光标所在位置到行末端的所有文本。
cw:改变文字命令,即光标所有位置的文字将随着输入文字而改变,至到按下[Esc]。
r:替代字符命令,即光标所在位置的字符将被输入的字符替代,至到按下[Esc]。
R:替代多行字符命令,即光标所在位置到右边所有的字符将被输入的字符替代,至到按下[Esc]。
绝大多数这些指令都可以通过组合而提高其功能。
例如,如果你输入2dd,vi将删除两行文本。
剪切与粘贴等操作
与其它很多编辑器一样,你可以在文档中使用剪切与粘贴文本。以下命令是可以使用的最为简单的剪切与粘贴操作。
yy 复制行命令。光标所有行的文本将被复制到类似剪切板的缓冲器。注意到可以使用多个复制命令更改这一命令以将多行文字剪切到缓冲器。
yl 复制字符命令。光标所有行的字符将被复制到类似剪切板的缓冲器。可以使用多个复制命令更改这一命令以将多行字符剪切到缓冲器。
p 后放置命令。在当前光标位置之后放置或粘贴缓冲器的内容。对于复制行命令,缓冲器的内容将被粘贴在当前行之后。对于复制字符行命令,缓冲器内容将被粘贴在光标的右边。
P 前放置命令。在当前光标位置之前放置或粘贴缓冲器的内容。对于复制行命令,缓冲器的内容将被粘贴在当前行之前。对于复制字符行命令,缓冲器内容将被粘贴在光标的左边。
使用复制和放置指令时,你也可以字符指令而使用多个缓冲器或剪切板。这些字符可为a-z,并且只能是小写字母。例如,ayy将当前行内容复制到缓冲器A,ap命令将缓冲器的内容粘贴在当前行之前。
Vi中最为重要的命令要算undo指令。这一命令十分简单:只需要按下u。按下u键就可以撤消最近使用的一次指令。 与undo命令类似的是redo命令。按下句号键(.)将会重新键入最近的指令。例如,如果你使用cw来改变一个文字,你可以查找这一文字然后使用句号.来这一文字。
其它两个重要的命令为search命令。为了在文档中向前查找,可键入/text,text即为你查找的内容。重要的是一定注意,只有输入内容完全的匹配,你才可以查找到。Vi不支持混合查询或者模糊查询。对于向后查找,可键入?text,text即为查找的内容。
编辑指令
在指令模式中,很多组命令都可以前缀:。与以上提及的命令不一样,一旦输入一个冒号,所有指令都出现在屏幕的左下角,并可以在执行之前编辑。以下是常用的重要的:指令。 :w 编写文件命令。如果你输入:w然后回车,当前文件将被写入硬盘。如果使用的是一个空白文档,将会出现“没有当前的文件名”的消息。可以使用:w文件名将一个空白文档或当前文档写入到另一文件。
:w!或:w文件名 覆盖文件命令。如果输入:w!然后回车,文件将会被当前新输入的名称而覆盖。这可用于文件的覆盖。
:q 退出命令。如果正常保持,输入:q将会终止整个操作。
:q! 退出而不需要保持命令。在不需要保存文件的情况下退出。
:%s/find_text/replace_text/
查询与替代命令
正如上面提及一样,可以改变查询命令为一个查询与替代命令。使用:%s命令可以告诉vi查询文档中所有行。/find_text命令与以上的查询命令类似,当其后缀/replace_text/,时,/find_text操作结果的第一行将会被替代。为了将/find_text所有内容被替代,可以增加一个g(全局),比如:%s/find_text/replace_text/g。
你不要只使用单一的指令。你可以将多个指令结合使用。例如,:wq!将会保存文件到硬盘并退出vi而返回到指令状态。 Vi=包含全部(Very involved) 以上提及的内容只是vi功能的一小部分。你可以一起执行指令串,以标记方式复制而粘贴文本,或者使用sed指令。你还可以将shell script的输出或其它指令插入到你的文档中。 以上涉及到的例子和指令将可以带你进入vi的大门。很多vi使用者在操作时都会记住一些命令。从其它使用vi的人可以学会更多的vi指令,而此时你或许惊叹vi的强大。然而,你应该记住一点:经常地使用:a指令,因为vi没有提供自动后台文档保存功能。
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
pw是一个用来创建、删除、修改、显示用户和组的命令行工具。它还有系统用户和组文件编辑器的功能。
1.pw命令格式:
1.1组管理
1.1.1组添加
pw [-V etcdir] groupadd [group|gid] [-C config] [-q] [-n group] [-g gid]
[-M members] [-o] [-h fd | -H fd] [-N] [-P] [-Y]
1.1.2组删除
pw [-V etcdir] groupdel [group|gid] [-n name] [-g gid] [-Y]
1.1.3组更改
pw [-V etcdir] groupmod [group|gid] [-C config] [-q] [-n name] [-g gid]
[-l name] [-M members] [-m newmembers] [-h fd | -H fd] [-N] [-P] [-Y]
1.1.4组显示
pw [-V etcdir] groupshow [group|gid] [-n name] [-g gid] [-F] [-P] [-a]
1.1.5 显示可建新组ID
pw [-V etcdir] groupnext [-C config] [-q]
1.2用户管理
1.2.1(1) 用户添加
pw [-V etcdir] useradd [name|uid] [-C config] [-q] [-n name] [-u uid] [-c comment]
[-d dir] [-e date] [-p date] [-g group] [-G grouplist] [-m] [-k dir]
[-w method] [-s shell] [-o] [-L class] [-h fd | -H fd] [-N] [-P] [-Y]
1.2.1(2)用户添加
pw [-V etcdir] useradd [name|uid] -D [-C config] [-q] [-b dir] [-e days]
[-p days] [-g group] [-G grouplist] [-k dir] [-u min,max] [-i min,max]
[-w method] [-s shell] [-y path]
1.2.2 用户删除
pw [-V etcdir] userdel [name|uid] [-n name] [-u uid] [-r] [-Y]
1.2.3 用户更改
pw [-V etcdir] usermod [name|uid] [-C config] [-q] [-n name] [-u uid] [-c comment]
[-d dir] [-e date] [-p date] [-g group] [-G grouplist] [-l name] [-m] [-k dir]
[-w method] [-s shell] [-L class] [-h fd | -H fd] [-N] [-P] [-Y]
1.2.4 显示用户
pw [-V etcdir] usershow [name|uid] [-n name] [-u uid] [-F] [-P] [-7] [-a]
1.2.5 可新建的用户ID
pw [-V etcdir] usernext [-C config] [-q]
1.2.6 锁定用户
pw [-V etcdir] lock [name|uid] [-C config] [-q]
1.2.7 用户解锁
pw [-V etcdir] unlock [name|uid] [-C config] [-q]
1.3常用选项解释
1.3.1用户操作时常用选项
[-V etcdir]
默认当新增组和用户时使用/etc/pw.conf作为pw配置文件,也可以指到别的文件上。pw.conf这个文件可以不存在。当使用这个参数时,需要使
用-C config
[-C config]
[-q] 在交互式环境中,这个选项使pw支持输出错误信息
[-N] 在添加和更改操作时输出结果,而不真正改变组和用户信息。
[-Y] 自动更新yp数据库。
[-n name] 指定用户名
[-u uid]指定用户id(ps:好像没什么用)
[-c comment]用户全称等注释信息(ps:没什么用)
[-d dir] 指定用户家目录
[-e date]帐号到期时间,时间格式可以是绝对的日-月-年,2为数字年或4位数字年,月可以是数字或英文月份的简写('Jan', 'Feb', etc);也
可以是相对时间,+n[分时天周月年],n可以是十进制、八进制[0开头]或十六进制[0x开头]。
[-p date]密码到期时间,时间格式同上。
[-g group]指定组(组名或组id)。
[-G grouplist]指定组列表,组以空格分开,如:-G wheel mysql teczm即把某账号置于这三个组内。
[-L class]在用户创建时指定登录等级。
[-m] 自动创建用户家目录
[-s shell]指定用户shell
[-w method]method包括:
no 新创建的账号禁止登录
yes 强制新建账号密码和账号一样(ps:这样不安全)
none 强制新建账号使用空密码(ps:这样不安全)
random 生成一个随机密码
ps:pw useradd username -g tests -d /home/test -s /bin/sh -h 0
增加参数 -h 0 可以出来password for user username:这样的提示来让你设定username的密码
1.3.2组操作时常用选项
[-M memberlist] 将用户置于组内,会替换掉已经存在的用户
[-m newmembers] 添加新用户到组内,不会替换掉已经存在的用户
示例:
1.新建一个用户bsder使用cshell,家目录为[color]/home/bsder[/color],属于组[color]wheel[/color],口令交互输入
#pw useradd bsder -s /bin/csh -d /home/bsder -m -g wheel -h 0
2.将bsder使用的shell改为/bin/sh
#pw usermod bsder -s /bin/sh
3.将bsder置于test组内
#pw groupmod test -m bsder
4.锁定bsder用户帐号
#pw lock bsder
5.对bsder账号解锁
#pw unlock bsder
6.显示bsder用户属性
#pw usershow bsder
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章
1.pw命令格式:
1.1组管理
1.1.1组添加
pw [-V etcdir] groupadd [group|gid] [-C config] [-q] [-n group] [-g gid]
[-M members] [-o] [-h fd | -H fd] [-N] [-P] [-Y]
1.1.2组删除
pw [-V etcdir] groupdel [group|gid] [-n name] [-g gid] [-Y]
1.1.3组更改
pw [-V etcdir] groupmod [group|gid] [-C config] [-q] [-n name] [-g gid]
[-l name] [-M members] [-m newmembers] [-h fd | -H fd] [-N] [-P] [-Y]
1.1.4组显示
pw [-V etcdir] groupshow [group|gid] [-n name] [-g gid] [-F] [-P] [-a]
1.1.5 显示可建新组ID
pw [-V etcdir] groupnext [-C config] [-q]
1.2用户管理
1.2.1(1) 用户添加
pw [-V etcdir] useradd [name|uid] [-C config] [-q] [-n name] [-u uid] [-c comment]
[-d dir] [-e date] [-p date] [-g group] [-G grouplist] [-m] [-k dir]
[-w method] [-s shell] [-o] [-L class] [-h fd | -H fd] [-N] [-P] [-Y]
1.2.1(2)用户添加
pw [-V etcdir] useradd [name|uid] -D [-C config] [-q] [-b dir] [-e days]
[-p days] [-g group] [-G grouplist] [-k dir] [-u min,max] [-i min,max]
[-w method] [-s shell] [-y path]
1.2.2 用户删除
pw [-V etcdir] userdel [name|uid] [-n name] [-u uid] [-r] [-Y]
1.2.3 用户更改
pw [-V etcdir] usermod [name|uid] [-C config] [-q] [-n name] [-u uid] [-c comment]
[-d dir] [-e date] [-p date] [-g group] [-G grouplist] [-l name] [-m] [-k dir]
[-w method] [-s shell] [-L class] [-h fd | -H fd] [-N] [-P] [-Y]
1.2.4 显示用户
pw [-V etcdir] usershow [name|uid] [-n name] [-u uid] [-F] [-P] [-7] [-a]
1.2.5 可新建的用户ID
pw [-V etcdir] usernext [-C config] [-q]
1.2.6 锁定用户
pw [-V etcdir] lock [name|uid] [-C config] [-q]
1.2.7 用户解锁
pw [-V etcdir] unlock [name|uid] [-C config] [-q]
1.3常用选项解释
1.3.1用户操作时常用选项
[-V etcdir]
默认当新增组和用户时使用/etc/pw.conf作为pw配置文件,也可以指到别的文件上。pw.conf这个文件可以不存在。当使用这个参数时,需要使
用-C config
[-C config]
[-q] 在交互式环境中,这个选项使pw支持输出错误信息
[-N] 在添加和更改操作时输出结果,而不真正改变组和用户信息。
[-Y] 自动更新yp数据库。
[-n name] 指定用户名
[-u uid]指定用户id(ps:好像没什么用)
[-c comment]用户全称等注释信息(ps:没什么用)
[-d dir] 指定用户家目录
[-e date]帐号到期时间,时间格式可以是绝对的日-月-年,2为数字年或4位数字年,月可以是数字或英文月份的简写('Jan', 'Feb', etc);也
可以是相对时间,+n[分时天周月年],n可以是十进制、八进制[0开头]或十六进制[0x开头]。
[-p date]密码到期时间,时间格式同上。
[-g group]指定组(组名或组id)。
[-G grouplist]指定组列表,组以空格分开,如:-G wheel mysql teczm即把某账号置于这三个组内。
[-L class]在用户创建时指定登录等级。
[-m] 自动创建用户家目录
[-s shell]指定用户shell
[-w method]method包括:
no 新创建的账号禁止登录
yes 强制新建账号密码和账号一样(ps:这样不安全)
none 强制新建账号使用空密码(ps:这样不安全)
random 生成一个随机密码
ps:pw useradd username -g tests -d /home/test -s /bin/sh -h 0
增加参数 -h 0 可以出来password for user username:这样的提示来让你设定username的密码
1.3.2组操作时常用选项
[-M memberlist] 将用户置于组内,会替换掉已经存在的用户
[-m newmembers] 添加新用户到组内,不会替换掉已经存在的用户
示例:
1.新建一个用户bsder使用cshell,家目录为[color]/home/bsder[/color],属于组[color]wheel[/color],口令交互输入
#pw useradd bsder -s /bin/csh -d /home/bsder -m -g wheel -h 0
2.将bsder使用的shell改为/bin/sh
#pw usermod bsder -s /bin/sh
3.将bsder置于test组内
#pw groupmod test -m bsder
4.锁定bsder用户帐号
#pw lock bsder
5.对bsder账号解锁
#pw unlock bsder
6.显示bsder用户属性
#pw usershow bsder
现在ArthurXF本人正在搞PHP等技术培训,如果想学习的人可以跟我联系。另外培训的招生简章在这个网址,想了解的可以去看看。加我QQ:29011218交流也可。
PHP培训招生简章





2007/06/30 16:49 
