FreeBSD命令大全

FreeBSD命令大全

如果你从unix转到FreeBSD来,那么你一定对他的命令会比较熟悉。

1 man 在线查询 man ls
2 ls 查看目录与档案 ls -la
3 ln 建立链接文件 ln -fs /usr/local/apache/etc/httpd.conf /etc/httpd.conf
4 more 分页显示 more 文件名称
5 cd 切换目录 cd /usr/local/apache
6 mkdir 建立新的目录 mkdir /usr/temp
7 rmdir 删除目录 rmdir /usr/temp
8 rm 删除目录或档案 rm -f 文件名称 (如果要删除目录.需要加 -r )
9 cp 复制目录或档案 cp 来源档案 目标档案
10 pwd 显示目前的工作目录
11 mv 目录或档案更名或搬移 mv 来源档案 目标档案
12 find 寻找目录或档案 find /etc -name 文件名称
13 fetch FTP取得档案 fetch ftp://ftp.center.kl.edu.tw/pub/FreeBSD/test.tgz
14 chmod 变更档案使用权限 chmod -R 755 /usr/local/etc
15 chown 变更档案所有者 chown -R lin.wheel /usr/local/etc
16 fsck 修理档案系统 fsck -y
17 gzip/tar 压缩或解压缩档案或目录 tar -czvf 压缩档名.tar.gz 目录名称
18 mount 挂上档案系统或是设备 mount /cdrom
19 umount 卸下档案系统或是设备 umount /cdrom
20 df 查询系统的可使用档案空间 df
21 du 显示目录或档案所占的磁盘空间 du -a 檔名 (du -sh 可以获取当前文件夹下的磁盘使用空间)
22 ps 查询系统process状态 ps -aux|grep apach*
23 kill 砍除一个process kill pid
24 su 变换身份 su – root
25 adduser 新增使用者
26 rmuser 删除使用者
27 vipw 编辑使用者账户
28 passwd 变更密码
29 ping 侦测计算机之联机状态 ping 210.240.6.9
30 ifconfig 网络接口的设定与管理 ifconfig -a
31 route 可以设定routing table
32 traceroute 列出所经过的route traceroute 210.240.8.1
33 netstat 可以查询网络的使用及联机情形
34 pkg_add 安装package pkg_add bash-2.04.tgz
35 pkg_delete 移除已安装的package pkg_delete bash-2.04
36 pkg_info 查询安装纪录
37 sync 强迫系统将快取数据写回硬盘
38 reboot重新启动系统
39 halt 关闭系统
40 shutdown 通知使用者系统将关闭
41 init 0 直接关机

chown chown -R 所有者.群组 档案或目录
-R:表该目录下之所有档案之所有者与群组跟着便变更

chmod
drwxrwxrwx
lr–rwxr-x
1 2 3 4
d:表目录
r:表read
w:表write
x:表可执行
-:表关闭功能

l:表链接的档案
2:该档案或目录所有人之读取权限
3:该档案或目录所有人之相同群组的读取权限
4:网络上的人的读取权限
-R:表该目录下之所有档案之读取权限跟着便变更

gzip/tar
tar czvf 压缩档名.tar.gz 目录名称
z:采用gzip压缩
c:建立新的压缩档
v:采用verbose方式,观看压缩过程
f:强制进行

tar zxvf 压缩档名.tar.gz
z:采用gzip解压缩
x:解压缩
v:采用verbose方式,观看压缩过程
f:强制进行

ifconfig
查询所有网络接口的情形
ifconfig -a

设定网络接口的参数
ifconfig de0 192.168.1.10 netmask 255.255.255.0

停止网络接口
ifconfig de0 down

启动网络接口
ifconfig de0 up

route
改变 routing path 之gateway
route change default 192.168.1.254

netstat
查询 routing table
netstat -rn

查询网络接口流量统计
netstat -I
查询 TCP网络联机情形
netstat -t
查询所有网络联机情形
netstat -a

shutdown
通知使用者多久后关机,管理者需下reboot或halt
shutdown -k 时间 讯息
通知使用者多久后重新启动系统
shutdown -r 时间 讯息
通知使用者多久后关闭系统
shutdown -h 时间 讯息

时间:now或+3表三分钟后或yymmddhhmm
讯息:用双引号括起来或用-号开头

一些常用的其它组合命令:
shift+g 同win下的END键,让光标处在文档末尾.
:/ 功能是在文档内进行文本搜索
:find 这个是文件的搜索

ls -l |more 内容过多时候..分屏显示

原文链接:http://www.majormoves.net/post/222/

FreeBSD基本命令整理

FreeBSD基本命令整理

第一步

我如何离线?(exit)
我如何停止电脑?(shutdown -h now)
我如何重新激活计算机? (shutdown -r now)
我如何在单使用者模式下停止系统? (shutdown now)
我如何切换终端机? (ALT-F*)

文件

我如何阅读 manual page? (man)

使用者管理 (1)

我该如何增加一个使用者? (adduser)
我如何移除使用者? (rmuser)
我如何改变我的密码? (passwd)

“su” 指令

我如何 “su” 至 root 帐号? (su)
我如何 “su” 至其它使用者的帐号? (su username)

四处观察

我在哪? (pwd)
我如何观察目录下有什么? (ls)
我如何看到以点开始的隐藏档? (ls -a)
我如何看到更多的讯息 (存取许可,拥有者,群组,大小,日期)? (ls -l)
我如何看出那些档是什么? (ls -F)
这些是什么档: “..” 与 “.”? (ls -aF)

四处移动

我该如何改变工作目录? (cd)
如何回到上一层目录? (cd ..)
我如何回到自己的工作目录? (cd, cd ~/)

屏幕控制

我如何卷回 (在终端机中,非 X)? (The Scroll Lock Key)
我该如何清除屏幕? (clear)

文章

我如何不使用文书编辑器就可以观看小的档案? (more)
最普遍的文书编辑器是? (vi)
“vi” 看起来有点难,我可以从 “ee” 开始吗? (ee)

“visual” 编辑器

学习 “vi” 最有效的方法为何? (vilearn)
“vi” 是如何工作的? (man vi)
什么是储存指命? (:w)
什么是离开指令? (:q)
什么是可以储存与离开的命令? (:wq)
如何离开而不使用储存指令? (:q!)
我如何移动? (h, j, k, and l)
Esc 键有什么用途? (The Esc Key)
我如何加入新的文字? (a and i)
我如何建立新的一行? (o and O)
我如何删除文字? (x and dd)
我如何拷贝文章内容? (yy and p)
我如何替代文章? ®
我如何使用数个指令? (nCommand)
我如何搜寻文章? (/text)
我如何起动 “vi” 于只读模式? (view)

使用者管理 (2)
我如何新增使用者至群组? (vi /etc/group)

计算机信息

我如何能观看开机记录文件? (dmesg)
有什么方法可以让我慢慢地观看开机记录文件吗? (dmesg |more)

显示谁在系统上? (who)
他们正在做什么?? (w)
“w” 可以显示出所有的处理吗? (w)

何时

我如何显示或设定日期时间? (date)
我如何显示月历? (cal)
有什么方法可以让我慢慢地观看月历吗? (cal | more)

Communications(通讯)

我如何显示 (或不显示) 其它使用者送来的讯息? (mesg y, mesg n)
我如何传送讯息到其使用者的屏幕? (write)
我如何送讯息到每一个人的屏幕? (wall)
我如何与他人交谈 (chat)? (talk)

档案管理

我如何建立一个空档案? (touch)
我如何删除档案? (rm)
我如何建立一个目录? (mkdir)
我如何移除一个空的目录? (rmdir)
我如何移除一个目录包括里面所有的东西 (包括子目录)? (rm -r)
我如何移除以 “-” 起头的档案? (rm — -filename)
我如何拷贝档案? (cp)
我如何拷贝整个目录包括它所有的内容? (cp -R)
我该如何搬移档案与目录? (mv)
我如何改变档案/目录名称? (mv)
我如何执行 rm、cp 与 mv 时,须要我的许可? (-i)
我如何执行 rm、cp 与 mv 时,不须要我的确认? (-f)

档案连结

我如何连结一个档案或目录? (ln -s)
我如何 hard link 一个档案? (ln)

档案拥有权/存取许可

我如何观察谁是档案拥有者? (ls -l)
我如何观察档案/目录的存取许可? (ls -l)
我如何改变档案/目录的使用者拥有人? (chown)
我如何改变档案/目录的群组拥有人?s group owner? (chgrp)
我如何改变档案/目录的使用者与群组拥有人? (chown user:group)
我如何改变存取许可? (chmod)
如果我拥有这个目录,我可否修改不是我的档案? (yes)

软盘机装置

我如何挂上我的软盘? (mount)
我如何挂上 MS-DOS 格式的软盘机? (mount -t msdos)
我如何卸下我的软盘? (umount)

应用程序

我如何起动应用程序? (./)
我如何由文件名称来起动应用程序? (PATH)
我如何在背景起动应用程序? (&)
我如何知道我的 PATH 是? (echo $PATH)
所有的应用程序在那? (The FreeBSD Ports Collection)
我如何安装一个 port? (make install clean)
那里有编辑好的二进制文件? (The FreeBSD Packages Collection)
我如何移除应用程序? (pkg_delete)

使用者环境

使用者的 profile 档案在那? (vi ~/.profile)
我如何改变我的 shell? (chsh)

处理管理

我如何列出处理? (ps)
我如何列找到处理? (ps -waux | grep “name of the process”)
我如何砍掉处理? (kill)

磁盘管理

我如何检查可用的磁盘空间? (df)
我如何检查每个目录下用了多少磁盘空间? (du)

工具

哪里有计算器? (bc)

原文链接:http://www.majormoves.net/post/223/

FreeBSD下查看某目录下文件的个数

FreeBSD下查看某目录下文件的个数

ls -l |grep "^-"|wc -l

find ./company -type f | wc -l

查看某目录下文件的个数,包括子目录里的。

ls -lR|grep "^-"|wc -l

查看某文件夹下目录的个数,包括子目录里的。

ls -lR|grep "^d"|wc -l

说明:

ls -l

长列表输出该目录下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等)

grep "^-"

这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d

wc -l

统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于一行信息对应一个文件,所以也就是文件的个数。

原文链接:http://www.majormoves.net/post/189/

FreeBSD find命令详解

FreeBSD find命令详解

find命令是功能最强的命令之一,但同时也是命令行结构最难以掌握的命令之一。
# find / -print | wc -l 显示系统中所有文件和目录的数目。
# find / -user $LOGNAME -print 显示系统中该用户所有文件和目录。
# find / -size 100 -print 显示文件大小为100 blocks。
# find / -size -100 -print 显示文件大小小于100 blocks 。
# find / -size +100 -print 显示文件大小大于100 blocks 。
# find / -name core -exec rm {} \;查找并删除core文件。
# find . -exec chown $LOGNAME {} \; 修改一个目录下的所有文件的用户所属。
# find .-type d -exec chmod 770 {} \;修改一个目录下的所有目录的权限。

find :(以下均在hp-unix下操作的)
find ./dir -mtime +10 -exec rm -rf {}\; 在dir目录下找到10天之前的文件,然后删除。 exec选项后面跟随着所要执行的命令,然后是一对儿{ },一个空格和一个\,最后是一个分号。
find ./dir -mtime +20 | xargs rm 在dir目录找到20天之前的文件并删除。 xargs 比直接带-exec选项的效率和性能都好
find ./dir -mtime -2 在dir目录下查找两天之内的文件
find ./dir -mtime +3 在dir目录下查找三天之前的文件
find ./dir -user fly 在dir目录下查找属于fly用户的文件
find ./dir -group user 在dir目录下查找属于user组的文件
find ./dir -type d 在dir目录下查找文件类型为目录的文件
find ./dir -name "*.sh" -depth  在使用find命令时,可能希望先匹配所有的文件,再在子目录中查找。使用depth选项就可以使find命令这样做

找unix机器中所有包含“jdbc/WapDataSource”字符串的文件

find / grep "jdbc/WapDataSource"

find / -name httpd.conf
find / -name access_log 2>/dev/null
find /etc -name ‘*srm*’
find / -amin -10 # 查找在系统中最后10分钟访问的文件
find / -atime -2 # 查找在系统中最后48小时访问的文件
find / -mmin -5 # 查找在系统中最后5分钟里修改过的文件
find / -mtime -1 #查找在系统中最后24小时里修改过的文件
find / -cmin -5 # 查找在系统中最后5分钟里被改变状态的文件
find / -ctime -1 #查找在系统中最后24小时里被改变状态的文件
find / -user reda #查找在系统中属于fred这个用户的文件
find / -not -user reda #查找在系统中不属于FRED这个用户的文件
find / -group redagrp # 查找在系统中属于redagrp组的文件
find / -gid 501 #查找系统中属于组id为501的文件
find / -user fred -a -group redagrp
find / -user reda -o -user tracy
find / -nouser #查找在系统中属于作废用户的文件
find / -empty # 查找在系统中为空的文件或者为空的文件夹
find / -false #查找系统中总是错误的文件
find / -size +5k #查找系统中大于5k字节的文件
find / -size +5c #查找系统中大于5字节的文件
find / -perm +6000
find / -type b
文件类型:
b 块(缓冲)设备.
c 字符设备.
d 目录.
p 有名管道(FIFO).
f 规则文件.
l 符号链结.
s 插座.
find / -maxdepth 2 -name fred
find /tmp -size +10000000c -and -mtime +2
find / -user reda -or -user tracy
find /tmp ! -user reda
find / -name ‘httpd.conf’ -ls
find / -user reda -exec ls -l {} \;
find / -user reda -ok #确认后执行
find / -user reda | xargs ls –l

原文链接:http://www.majormoves.net/post/188/

FreeBSD chgrp命令详解

FreeBSD chgrp命令详解

chgrp,修改文件或目录的所属组。

chgrp [options] newgroup files/directorys

组名可以用组的ID号,也可用/etc/group中的组名。只有文件的属主或特权用户(root)才可改变它的组。

options:

-c,–changes

只输出被改变文件的信息

-f,–silent,–quiet

当不能改变文件组属性时,不通知文件的用户

–help

输出帮助信息。

-R,–recursive

可递归遍历子目录,把修改应到目录下所有文件和子目录

–reference=filename

参照filename的组信息来设置当前文件的组

-v,–verbose

输出详细信息

–version

输出版本信息。

实例:

$ chgrp root test把test的所属组更改root组

$ chgrp -R mysql test递归地把test目录及该目录下所有文件和子目录的组属性设置成mysql

$ chgrp root * 把当前目录中所有文件的组属性设置成root

3、chown—-设置一个或多个文件或目录的属主身份

chown [options] newowner files/directorys

新的属主可以是用户的ID号,也可以是/etc/passwd里的登录名。chown也可接受这样的形式:newowner:newgroup或newowner.newgroup。同时改变所属组的属性。如果句点和冒号后没有组名,则组改变为新属主的组。只有文件或目录的当前属主才有权改变它的属性。

options:

-c,–changes

只输出被改变文件的信息

–dereference

跟踪符号链接

-h,–no-dereference

改变每一个符号链的属主身份,而不是被引用文件的属主身份

-f,–silent,–quiet

当不能改变文件属主属性时,不通知文件的用户

–help

输出帮助信息。

-R,–recursive

可递归遍历子目录,把修改应到目录下所有文件和子目录

–reference=filename

把属主改变成filename文件的属主

-v,–verbose

输出详细信息

–version

输出版本信息。

实例:

$ chown root test把test文件的属主改进root

$ chown -R root test_directory递归地把test_directory目录下的所有文件属主改成root

$ chown –dereference root test_link把test_link链接的原文件属主改成root,链接文件属主不变

$ chown –no-dereference root test_link把test_link的链接文件属主改成root,原文件属主不变

原文链接:http://www.majormoves.net/post/181/

用PuTTY进行远程管理FreeBSD初学者笔记

用PuTTY进行远程管理FreeBSD初学者笔记

本人是一个FreeBSD系统的初学者,在学习当中遇到许多困难,因此想把安装及使用的过程做一个记录。因为学习及笔记当中参考了网上许多先辈的教程,在此表示感谢。本文是在FreeBSD实际环境使用后,进行记录的笔记,有不妥当之处还希望各位多多指正。

一 SSH简介

传统的网络服务程序,如:ftp、pop和telnet在本质上都是不安全的,因为它们在网络上用明文传送口令和数据,别有用心的人非常容易就可以截获这些口令和数据。而且,这些服务程序的安全验证方式也是有其弱点的,就是很容易受到“中间人”(man-in-the-middle)这种方式的攻击。所谓“中间人”的攻击方式,就是“中间人”冒充真正的服务器接收你的传给服务器的数据,然后再冒充你把数据传给真正的服务器。服务器和你之间的数据传送被“中间人”一转手做了手脚之后,就会出现很严重的问题。

SSH的英文全称是Secure Shell。通过使用SSH,你可以把所有传输的数据进行加密,这样“中间人”这种攻击方式就不可能实现了,而且也能够防止DNS和IP欺骗。还有一个额外的好处就是传输的数据是经过压缩的,所以可以加快传输的速度。SSH有很多功能,它既可以代替telnet,又可以为ftp、pop、甚至ppp提供一个安全的“通道”。

二 PuTTY简介

PuTTY 是一套免费的 SSH / Telnet 程序,它可以连接上支持 SSH Telnet 联机的站台,并且可自动取得对方的系统指纹码 (Fingerprint)。建立联机以后,所有的通讯内容都是以加密的方式传输,因此你再也不用害怕使用 Telnet 在 Internet 或公司的内部网络传输资料时被他人获知内容了!

三 PuTTY下载

1 下载putty.exe
[url]http://the.earth.li/~sgtatham/putty/0.60/x86/putty.exe[/url]

2 下载puttygen.exe
[url]http://the.earth.li/~sgtatham/putty/0.60/x86/puttygen.exe[/url]

四 生成密钥
运行puttygen.exe,点Generate按钮开始生成密钥(如图1),等待直至生成密钥。点下面的Save private key把私钥保存为扩展名是 .ppk 的文件(如图2)。此时不要关闭程序。

图1:生成密钥 图2:保存密钥文件

五 连接远程服务器,上传密钥

使用PuTTY登陆远程服务器,地址如192.168.0.1。在Session–>Host Name(or IP address)中输入192.168.0.1,如图3。

图3:连接远程服务器

在Connection–>Data–>Login details–>Auto-login username中输入初装系统时创建的wheel组用户,如admin,如果没有创建则新建一个用户,如图4。点Open按钮登陆远程服务器。图4:设置自动输入用户名

六 创建~/.ssh/authorized_keys

在远程服务器admin用户下创建~/.ssh/authorized_keys
$ mkdir ~/.ssh
$ cd ~/.ssh
$ ee authorized_keys
复制Puttygen.exe程序Public key for pasting into Open SSH authorized_keys file下面的内容,在服务器上的authorized_keys文件中按鼠标右键粘贴并保存退出。

七 使用Putty密钥方式验证自动登陆

打开Putty.exe,根据上述第五点,输入远程服务器IP地址及登陆用户名,并在Connection–>SSH–>Auth–>Private key file for authentication–>点Browser按钮选择上述第四点保存的.ppk文件,如图5。点Open按钮即可登陆远程服务器。

图5:设置密钥文件

原文链接:http://luhuayan.blog.51cto.com/261482/53636

FreeBSD初学者常用命令笔记

FreeBSD初学者常用命令笔记

一 系统登录与退出

1 系统登录

系统在执行完引导和启动脚本后,FreeBSD将读取/etc/ttys文件,按照配置启动多个虚拟控制台,在控制台上启动登录进程login,以接受用户登录。

FreeBSD虚拟控制台默认配置为8个,使用者可以使用Alt-F1-Alt-F8等功能键在不同的控制台之间进行切换。

当控制台出现login提示后,可以使用root用户和安装时设置的root口令登录系统。

例:
FreeBSD/i386 (lhy.gl.com) (ttyv0)
login: root
Password:

2 退出

当工作完成后,可以使用logout命令退出当前会话。
使用exit,或使用Ctrl-D(^D)都能结束当前会话,退出登录过程。

例:
# logout
也可以用:
# exit

3 关闭系统

关机需要以root身份登录进入系统之后,使用shutdown命令来进行关闭系统。
-h 参数,表示halt,停机操作。

例:
# shutdown -h now
Now参数表示立即执行shutdown命令。

也可以用halt命令立即执行停机操作。
# halt
-r 参数,表示reboot,重新启动系统。

例:
# shutdown -r +5 “Please logout”
表示五分种后重启系统,并向正登录的用户发送广播信息。

也可以用reboot命令立即重新启动系统。
# reboot
-p 参数,表示关闭计算机。

例:
# shutdown -p now
表示立即关闭计算机。

二 用户管理

1 增加用户

例:
# adduser

2 修改用户口令

# passwd

3 从普通用户升级为超级用户

例:
$ su
Password:
#
正确输入root的口令后,就成为了超级用户,系统提示符也从标准的“$”变为root专用的“#”提示。
在FreeBSD上要使用su命令成为root用户,不但要知道root的口令,还需要经过特别设置,否则就不能成功的使用这个命令,能使用su命令的用户必须属于wheel组。

三 文件复制、删除和移动

1 文件复制命令(cp)

例:
# cp rc.conf rc.conf.old
# cp –r /usr/xu/ /usr/liu/
将/usr/xu目录中的所有文件及其子目录拷贝到目录/usr/liu中。

2 文件移动命令(mv)

例:
# mv index.php index1.php
表示将index.php重命名为index1.php。
# mv phpMyAdmin phpMyAdmin1
表示将phpMyAdmin目录重命名为phpMyAdmin1。

3 文件删除命令(rm)

例:
# rm index.php
表示删除index.php文件。
# rm –r phpMyAdmin
表示将phpMyAdmin目录及其子目录全部删除。

四 目录的创建及删除命令

1 目录创建命令(mkdir)

例:
# mkdir /ftproot

2 目录删除命令(rmdir)

例:
# rmdir phpMyAdmin
表示删除空目录。
# rmdir –p phpMyAdmin
表示将phpMyAdmin目录及其子目录全部删除。

3 改变工作目录

例:
# cd ..
回到上一级目录。
# cd /
回到根目录。
# cd ~/
回到当前用户根。

4 显示当前工作目录的绝对路径

# pwd

5 列出目录的内容(ls)

-a 参数,显示指定目录下所有子目录与文件,包括隐藏文件。
-F 参数,在目录名后面标记“/”,可执行文件后面标记“*”,符号链接后面标记“@”,管道(或FIFO)后面标记“|”,socket文件后面标记“=”。
-l 参数,以长格式来显示文件的详细信息。

例:
# ls -laF
# ls |more
列目录,使用管道和more命令分屏显示过多的内容。

五 备份与压缩命令

tar命令
x 参数,从档案文件中释放文件。
z 参数,用gzip来压缩/解压文件。
v 参数,显示文件的归档进度。
f 参数,使用档案文件或设备,这个选项通常是必选的。

例:
# tar xzvf NVIDIA-FreeBSD-x86-100.14.11.tar.gz

六 常用网络命令

1 配置网络

# ifconfig re0 inet 192.168.0.1 netmask 255.255.255.0 up
其中re0表示第一个以太网接口,inet表示这块网卡有一个Internet(inet)地址,设置本网络地址为192.168.0.1,子网掩码为255.255.255.0,up表示这块网卡已经配置完成准备工作。
也可以使用以下的命令进行配置。
# ifconfig re0 192.168.0.1
# ifconfig
显示当前网络的配置信息。

2 测试以太网卡

# ping 192.168.0.1
七 进程管理

例:
$ ps
表示查看进程及其状态。
$ ps waux
输出系统中所有的进程。
$ kill 829
终止进程标识号PID为829的进程。

八 查看命令的详细说明

# man ls
查看ls命令的详细说明。

九 文本编辑器

FreeBSD 的很多配置都可以通过编辑文本文件来完成,最容易学的而又简单的编辑器是ee编辑器。

例:
# ee /etc/rc.conf
表示编辑/etc/rc.conf文件。在ee的控制内,编辑器所有功能的操作方法都显示在最上方。 这个^ 字符代表 键盘上的Ctrl 键, 所以^e 就是 Ctrl+e组合键。假如想离开ee, 按Esc键,就可选择离开编辑器。当您修改了内容的时候,编辑器会提示您保存。

原文链接:http://luhuayan.blog.51cto.com/261482/53840

FreeBSD软件安装卸载工具–Ports和Packages详解

FreeBSD软件安装卸载工具

Ports和Packages详解

摘抄并简体化此文,与初学同仁共享。
==================================
FNP:FAQ – Ports and Packages v 1.5
2004.08.20 Table of Contents
1、如何只抓取 tarball?
2、如何仅做到解开 tarball的步骤?
3、如何仅做到解开 tarball 并补上官方提供的 patch?
4、如何安装一个新的 port?
5、如何安装一个新的 port,并将打包(package)起来?
6、如何打包一个 port,并将其所有相依的 ports 也打包起来?
7、如何对一个已经安装的 port 打包?
8、如何清理 ports 编辑期间所产生的暂存资料?
9、如何清理 ports 编辑期间所产生的暂存资料,以及其相对应的 tarball?
10、如何在安装 ports 前查询所需依赖/相关的套件?
11、如何移除已安装的 ports?
12、如何一并移除所相依的 ports?
13、如何重新安装已安装过的 ports?
14、如何以关键字搜寻 ports?
15、如何升级已安装的 ports?
16、如何查询目前系统安装了哪些套件?
17、如何查询目前系统有没有安装这个关键字的套件?
18、如何查询某个档案是属於哪些套件?
19、如何查询某个套件安装了哪些档案?
20、如何安装旧版的 ports?
21、如何更新 ports Mk?
22、如何解决安装 ports 时出现 sed -i 的错误?
23、如何列出所有可以升级的 ports?
24、如何得知 ports system 对某个 ports 所提供的编译叁数?
25、如何手动加入编译 ports 的叁数?
26、如何指定 ports 的安装路径?
27、安装 ports 出现 FORCE_PKG_REGISTER 的错误讯息
28、安装 ports 出现 Shared object libintl.so.X not found 的错误讯息
29、如何安装 packages?
30、如何强制安装 packages?
31、如何查询 packages 与其他 packages 之间的相依性?
32、如何远端安装 packages?
33、如何更新 INDEX 对照表?
34、如何更新 INDEX HTML?
35、如何针对某些 ports 不做 CVSup?
36、如何使用 CVSup 同步 ports collections?
37、安装 ports 出现 port is outdated 的错误讯息
39、安装 ports 出现 OpenSSL vulnerabilities 的错误讯息
40、如何在 FreeBSD 上模拟 Linux 的环境?
41、如何在 FreeBSD 上安装 Linux rpm?
42、安装 ports 时,原本应该出现的清单选项不见了
43、如何检查是否有安装重覆的 ports/packages? `make deinstall’ 与 `pkg_delete’ 有什麽不同?
44、安装 ports 出现 local modification time does not match remote 的错误讯息

1、如何只抓取 tarball?

如果只希望抓取 tarball 下来的话,仅需下 make fetch 即可。
如果是要抓取单一的 port,以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make fetch

预设会将 joe 的 tarball 下载至 /usr/ports/distfiles/ 目录下。
如果是希望抓取安装此 ports 所有须要的其他 ports 的 tarball,以systuils/portupgrade 为例的话,则:

cd /usr/ports/systuils/portupgrade/
make fetch-recursive

预设会将此 ports 的 tarball 与所有须要的其他 ports 的 tarball,下载至 /usr/ports/distfiles/ 目录下。
如果是希望抓取全部所有 ports 的 tarball ,则:

cd /usr/ports/
make fetch

则会所将全部所有 ports 的 tarball 下载至 /usr/ports/distfiles/ 目录下。
如果是希望抓取全部 ftp 下所有 ports 的 tarball ,则:

cd /usr/ports/ftp/
make fetch

则会所将全部 ftp 下所有 ports 的 tarball 下载至 /usr/ports/distfiles/目录下。

2、如何仅做到解开 tarball的步骤?

有时候习惯自己 patch/修正 原始码的时候,很常用到这个功能。以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make extract

会将 tarball解开至 /usr/ports/editors/joe/work/ 目录下。

3、如何仅做到解开 tarball 并补上官方提供的 patch?

此方法与 2 有一些类似,不同於是先补上官方提供的 patch ,再行 patch 自己的修正。以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make patch

会将 tarball解开至 /usr/ports/editors/joe/work/ 目录下,并已经 patch 上官方提供的 patch。

4、如何安装一个新的 port?

如果系统上未安装此软体,则可以选择安装一个新的 port。以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make install

如此会在系统上安装一个新的 joe 软体。如果需要在安装完成後,一并清除编辑时期所留下来的暂存目录,则可叁考 FAQ 8 的方法,一起使用,如:

cd /usr/ports/editors/joe/
make clean

如果想要一次清掉所有 ports 产生的暂存资料,则只要回到 ports 的根目录执行即可:

cd /usr/ports/
make clean

5、如何安装一个新的 port,并将打包(package)起来?

将安装完成的软体打包起来,有许多便利性:包括在丛集系统中,可供其它机器使用,或将未来此软体出问题可重新利用此 package 重新快速安装。
以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make package

如此会在系统上安装一个新的 joe 软体,并将此软体打包(package)起来。

package 预设会在 /usr/ports/editors/joe/ 目录下,如果希望集中管理的话,建议做如下的步骤:

mkdir -p /usr/ports/packages/All/

以後打包的 packages 都会存放在此目录下,并且系统会自动做分类,以方便管理。如果需要在安装完成後,一并清除编辑 时期所留下来的暂存目录,则可叁考 FAQ 8 的方法,一起使用,如:

cd /usr/ports/editors/joe/
make package clean

6、如何打包一个 port,并将其所有相依的 ports 也打包起来?

因为 FAQ 5 只有对最终的 port 才进行打包,中间依赖的 ports 并没有一起打包,这会出现一个常遇到 的问题,就是如果编辑一个 port 需要依赖其它的ports,那麽必须将其它 ports 也一起打包,否则安装 packages 会有相 依赖其它 ports 的 packages 的问题。
以 sysutils/portupgrade 为例的话,则:

cd /usr/ports/sysutils/portupgrade/
make DEPENDS_TARGET=package package

如此会在对所有 portupgrade 所相依赖的 ports 一并打包,也包括自己本身。

7、如何对一个已经安装的 port 打包?

如果安装好一个套软,事前并未打包,事後想打包的话,则:
以 editors/joe 为例的话

cd /var/db/pkg/
pkg_create -b joe-{版本号}

会将已安装的 port 打包起来,放在 /var/db/pkg/ 目录下。

8、如何清理 ports 编辑期间所产生的暂存资料?

在编辑 port 的时候,会有编辑期间所需要的工作目录(work),因此通常安装好一个套件後,会清除此暂存目录,以节省系 统磁碟空间。
以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make clean

如果是希望清除所有 ports 的暂存目录,则:

cd /usr/ports/
make clean

如果是希望清除全部 ftp 下所有的暂存目录,则:

cd /usr/ports/ftp/
make clean

9、如何清理 ports 编辑期间所产生的暂存资料,以及其相对应的 tarball?

在 FAQ 8 中,仅只是清除编辑期间所需要的工作目录(work),并没有将编译ports 时一并下载的 tarball 删除(相对应之 tarball 预设会存放在 /usr/ports/distfiles/),如果欲把 tarball 一并删除,以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make distclean

make distclean 的步骤包含了 make clean 的功能,也就是说除了会删除
tarball 外,还会一并M除编辑期间所需要的工作目录。

如果是希望清除所有 ports 的暂存目录,及 tarball ,则:

cd /usr/ports/
make distclean

如果是希望清除全部 ftp 下所有的暂存目录,及 tarball,则:

cd /usr/ports/ftp/
make distclean

10、如何在安装 ports 前查询所需依赖/相关的套件?

在安装 ports 前,可以查询所需依赖/相关的套件。
以 mail/p5-Mail-SpamAssassin 为例的话,则:

cd /usr/ports/mail/p5-Mail-SpamAssassin/
make all-depends-list #显示所有相关的套件
make pretty-print-build-depends-list #显示编译期间所需要的套件
make pretty-print-run-depends-list #显示此套件要执行时所需要的套件

11、如何移除已安装的 ports?

以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make deinstall

或是使用 pkg_delete

cd /var/db/pkg/
pkg_delete joe-{version}

有时候套件之间的相依性会导致无法直接移除,如果要强制移除的话,则:

cd /var/db/pkg/
pkg_delete -f joe-{version}

但很有可能会导致其它的套件执行起来出现问题。
至於二者的差别,请叁考FAQ 43

12、如何一并移除所相依的 ports?

以 sysutils/portupgrade 为例的话,则:

cd /usr/ports/sysutils/portupgrade/
make deinstall-depends

执行此步骤前,请注意是否会移除应该保护的套件。建议先叁考 FAQ 10 的方法来检查。
或是使用 pkg_delete

cd /var/db/pkg/
pkg_delete -r portupgrade-{version}

至於二者的差别,请叁考FAQ 43

13、如何重新安装已安装过的 ports?

重新安装的前提是,之前有安装过或目前已安装。以 editors/joe 为例的话,则:

cd /usr/ports/editors/joe/
make deinstall
make clean
make install 或 make reinstall

14、如何以关键字搜寻 ports?

如果要从全部的 ports collection 中找寻与关键字 “ldap” 有关的 ports,则:

cd /usr/ports/
make search key=ldap

如果只要从与 ftp 相关的 ports 下找寻与关键字 “ldap” 有关的 ports,则:

cd /usr/ports/ftp/
make search key=ldap

还有另一个用法,方法只是将 key 换成 name 。如果已经知道要搜寻 ports 的名称,或只想找名称相关的关键字 “ldap”, 则:

cd /usr/ports/
make search name=ldap

如果只要从 ftp 相关的 ports 下找寻名称与关键字 “ldap” 有关的 ports,则:

cd /usr/ports/ftp/
make search name=ldap

15、如何升级已安装的 ports?

如果已经安装好套件,事後欲升级的话,必须先移除旧版本的 port,移除的方法请叁考FAQ 11、FAQ 12及FAQ 13;之後再安装 port,安装的方法请叁考FAQ 4或FAQ 5。

以 editors/joe 为例,且以 FAQ 11 及 FAQ 4 的方法,则:

cd /var/db/pkg/
pkg_delete joe-{version}
cd /usr/ports/editors/joe/
make install

或是

cd /usr/ports/editors/joe/
make clean
make reinstall

16、如何查询目前系统安装了哪些套件?

查询目前系统已安装的全部套件:

pkg_info

17、如何查询目前系统有没有安装这个关键字的套件?

此方法类似 FAQ 16 :

pkg_info | grep

18、如何查询某个档案是属於哪些套件?

如果想查询 /usr/local/bin/joe 是属於哪个套件的话,则:

pkg_info -W /usr/local/bin/joe

如果没有回传任何资讯的话,代表着这个档案是由 FreeBSD 内建的。

19、如何查询某个套件安装了哪些档案?

如果想查询目前系统所安装的 joe 包含了哪些档案,则:

pkg_info -L /var/db/pkg/joe-{version}

20、如何安装旧版的 ports?

有时候会因为相依性,或是新版有问题,而会想装旧版本的套件。
这里的方法是利用 CVS 的好处,回归到以前旧版本存在的日子,以安装旧版本的套件。首先,若我们要回复到某一个套件的版本时,需要去查询 FreeBSD ports CVS repository。最常见的就是 Freshports 网站、 FreeBSD 的 Mailing FreeBSD cvs 或是 FreeBSD ports cvsweb。

查到该套件版本所依存的日子後,就修改 CVS tag。一般预设 ports 的 CVS tag 会写在 /usr/share/examples/cvsup/ports-supfile ,如要回朔到2002/10/05 号的话,则:

vi /usr/share/examples/cvsup/ports-supfile
******************************************
default date=2002.10.05.00.00.00 #将 date 改成当日

然後按照一般 CVSup 的时候一样,执行 CVSup (make update),此时的 ports collections 就会回到当时的情形,那麽该套件 旧版本也会出现在 ports collections 中,只要安装即可。

如果仅是想把某部份的 ports 回朔,则必须加上额外的资讯,如仅希望把lang/perl5.8 回朔,而得知此属於 lang 中的一支,则:

vi /usr/share/examples/cvsup/ports-supfile
******************************************
#ports-all #将 ports-all 标示起来
ports-lang #加入这行

最後,执行 CVSup,并安装即可。目前若希望单独回朔单一的 ports,则比较麻烦。

21、如何更新 ports Mk?

Mk (/usr/ports/Mk/) 是编译 ports 时所叁考的设定,有时若发生 ports collections 太新,而导致 Mk 的内容不符,此时 就是应该更新 Mk 的时候了。

cd /usr/src/
make update
cd /usr/src/share/mk
make install

22、如何解决安装 ports 时出现 sed -i 的错误?

因为 BSD style 的 sed ,也就是 BSD 本身自有的 sed ,与一些 ports 编译期间所执行的 sed 不一致,所以会导致一些语 法错误。此时先安装 sed_inplace (textproc/sed_inplace),然後再安装原本无法安装的 ports:

cd /usr/ports/???/???/
make -DUSE_REINPLACE install

23、如何列出所有可以升级的 ports?

ports collection 的更新速度很快,在每次更新 ports collections 後,往往会出现比目前现在安装的套件还新的版本,可 以令系统自行整理并提供可升级套件的列表:

pkg_version -c

24、如何得知 ports system 对某个 ports 所提供的编译叁数?

所有的 ports collections 中所提供的编译叁数都会在对应的 Makefile 档案内详述,如 sysutils/portupgrade 的话,则是位在 /usr/ports/sysutils/portupgrade/Makefile 档案下。
可以对此档案浏览以得知编译时期可以下达的叁数,如对 sysutils/portupgrade 有提供 NOPORTDOCS,则:

cd /usr/ports/sysutils/portupgrade/
make -DNOPORTDOCS install # make NOPORTDOCS=yes install 亦同

那麽安装此 ports 时,会将 NOPORTDOCS 所对应的相关叁数指定进去。有时候设定较人性化的 ports 会在安装前提供叁数供选择,但是其实大部份的ports 都没有提供,因此必须自行去搜寻可编 译的叁数,在此我提供的方式如下:

cd /usr/ports/sysutils/portupgrade/
grep defined Makefile

如此几乎可以知道所有提供的可编译叁数,虽然有时会多出一些不相干的资料,不会这个确实是一个不错可叁考的方式。

25、如何手动加入编译 ports 的叁数?

在 FAQ 24 中的方法,是 ports collections 有提供的前提之下,有时候并不是所有该软体所支援的叁数 都会收纳在 ports collections 中,因此有时候会需要手动加入编译的叁数。如 ftp/pure-ftpd 中,如果不想把 inetd 的支援编入的选项,并没有被 ports collections 所纳入,因此必须手动加上这个 编译叁数,如下:

cd /usr/ports/ftp/pure-ftpd/
make CONFIGURE_ARGS+=”–without-inetd” install

26、如何指定 ports 的安装路径?

预设 ports collecions 已安排安装的路径 (/usr/local/),如果不想将套件安装在预设路径的话,可以手动指定安装路径。 以 editors/joe 为例,则:

cd /usr/ports/editors/joe/
make PREFIX=/usr install

那麽 joe 就会将档案对应在 /usr 目录下,而不是预设的 /usr/local 目录下。

27、安装 ports 出现 FORCE_PKG_REGISTER 的错误讯息

问题叙述:
当你先前已经用ports 安装过某一软件当你要再次透过ports 安装同一软件时,很有可能会出现类似下述的错误讯息产生。

意思是说你可以透过make deinstall 解除安装然后透过make reinstall来重新安装。
若你确定想要*覆盖*此安装可以透过设定FORCE_PKG_REGISTER变量达成目标。

===> An older version of PORTS资料夹位置is already installed (软体版本)
You may wish to “make deinstall” and install this port again
by “make reinstall” to upgrade it properly.
If you really wish to overwrite the old port of PORTS资料夹位置
without deleting it first, set the variable “FORCE_PKG_REGISTER”
in your environment or the “make install” command line.

处理方式:
只要在make install 时加上FORCE_PKG_REGISTER=”yes” 就可以强制安装。
也就是:
cd /usr/ports/资料夹位址/
make install FORCE_PKG_REGISTER=”yes”

28、安装ports 出现Shared object libintl.so.X not found 的错误讯息

Shared object “libintl.so.4″ 或(libc.so.4) not found

问题叙述:
近来的FreeBSD版本,常常在安装某些软体时,会出现类似的失败画面并且告诉你缺乏libintl.so.4或是libc.so.4 这个函式

问题分析:
libintl.so 函式是安装/usr/port/devel/gettext/ 程式后取得。
理论上来说目前版本的相关函数是libintl.so.5 为何还要去读取旧的libintl.so.4 版本

当你在安装gmake时,gmake会去连结安装gmake当时的libinl.so的版本,是version 4
也就是 libintl.so.4

当你更新过相关的ports (devel/gettext) 将会用libintl.so.5 取代libintl.so.4
除非你能取得先前某些系统保留旧有的libintl.so.4 否则就会出现安装失败状况

很可惜的是…有很多程式需要gettext 函式。
你可以用cd /usr/ports/ ; make search key=”gettext” | more 查询
为什么要加上more 因为太多怕你看到昏头…QQ

问题解决:
要解决这个问题你可以透过重新建立所有与gettext 相关的ports程式。

portupgrade -fr gettext

重新建立或重新安装所有与gettext相关连的程式,若你忘掉了请参阅更新ports/升级系统> portupgrade 软体更新

或是简单的用偷吃步把*目前版本*link过去..QQ (版本6..类推)
然后就可以顺利进行程式安装。

29、如何安装 packages?

目前 FreeBSD 的 packages 是由 .tgz 所打包。如果想安装一个 packages ,可使用 pkg_add,如安装一个 joe 的 tgz:

pkg_add joe-{version}.tgz

30、如何强制安装 packages?

由於有些 packages 会有与其他 packages 相依性的关系,所以必须先行安装那些 packages 才能正常安装。 如果须要强制安装 packages ,可以不须安装那些有相依性 packages ,但要注意的是强制安装的结果可能会导致执行或运作的不正常。强制安装 packages 的指令如下,如强制安装一个 joe 的 tgz:

pkg_add -f joe-{version}.tgz

31、如何查询 packages 与其他 packages 之间的相依性?

由於有些 packages 会有与其他 packages 相依性的关系,所以必须先行安装那些 packages 才能正常安装。 查询 packages 与其他 packages 之间的相依性的指令如下,如查询与 portupgrade 相依的其他 packages:

pkg_info -r portupgrade-{version}.tgz

32、如何远端安装 packages?

有两种设定方式,首先是 PACKAGEROOT,如:

setenv PACKAGEROOT ftp://ftp.cn.freebsd.org #设定 PACKAGEROOT 为 ftp.cn.freebsd.org 站台

另一种方式是设定 PACKAGESITE,好处是若该站台的 packages 仓储并不是符合官方的设定或你想自己指定一个路径。
以 ftp.cn.freebsd.org i386 的 current pakcages 为例:

setenv PACKAGESITE ftp://ftp.cn.freebsd.org/pub/FreeBSD/ports/i386/packages-current/Latest/

两种方式选择其中一种皆可,接下来的步骤都一样。
往後要安装 packages 的时候,如 portupgrade 的话,则:

pkg_add -r portupgrade

则系统会自动於 ftp.cn.freebsd.org 抓取所有与 portupgrade 相依的 packages 并安装。

33、如何更新 INDEX 对照表?

4.x 的 INDEX 位於 /usr/ports/INDEX,5.x 位於 /usr/ports/INDEX-5。
INDEX 是对照 ports 所有相依等资讯的对照表,若长期未更新的话,会导致ports 对照失败。官方有定期更新 INDEX,如果 想自行更新的话,则:

cd /usr/ports/
make index

34、如何更新 INDEX HTML?

FreeBSD 提供了用网页的方式来观看 ports collection,即可使用 lynx, w3m, links 或其它可浏览网页的程式来查阅。制作全部 ports collection 的方式如下:

cd /usr/ports/
make readmes

如果是仅须要做目前目录下的资讯,或单一更新某一分类下的资讯,如 /usr/ports/ftp/ 的话,则:

cd /usr/ports/ftp/
make readme

则仅会更新 /usr/ports/ftp/ 这个目录的资讯,其上与其下的目录皆不会更动到。 执行成功後,会在相对应的目录下产生 README.html 的档案。

35、如何针对某些 ports 不做 CVSup?

若 ports 底下的某些分类完全用不到,则可以在 CVSup 时,不做更新,以节省网路频宽与时间。

vi /usr/sup/refuse
******************************************
ports/french
ports/german
ports/hebrew
ports/hungarian
ports/japanese

那麽则上述目录下的档案皆不会更新。
如果是想要某些单一的 ports 不做同步,例如想保留旧版不做同步,或新版出现问题时。

vi /usr/sup/refuse
******************************************
ports/lang/perl5.8

那麽 ports/lang/perl5.8 这个 ports 不会做 CVSup 同步。
这些设定方法支援万用字元。

vi /usr/sup/refuse
******************************************
ports/lang/perl*
ports/po*

36、如何使用 CVSup 同步 ports collections?

请叁考 gslin 的 用 CVSup 去更新你的 source tree 以及 ports tree。

37、安装 ports 出现 port is outdated 的错误讯息

例如安装 imap-uw 时,出现以下内容:
Your installation of the cclient port is outdated. Please delete it before continuing.

表示因为相对应,且已安装好的 cclient 这个软体过於老旧,建议先升级这个软体再行安装 imap-uw。因此只要先升级 cclient 後,再安装即可。

cd /usr/ports/mail/cclient/
make reinstall 或 # make deinstall && make install
cd /usr/ports/mail/imap-uw/
make install

38、安装 ports 出现 OpenSSL vulnerabilities 的错误讯息

在安装有些套件时,如果有相依於 OpenSSL 时,且判断系统目前使用的 OpenSSL 版本有漏洞问题时,会出现如下的讯息:
Dependency warning: used OpenSSL version contains known
vulnerabilities Please update or define either WITH_OPENSSL_BASE or
WITH_OPENSSL_PORT

一般建议的解决方法有二种。
第一种:升级系统(需含系统内建之 OpenSSL 一并升级),再安装该套件
可以先查询目前系统所用之 OpenSSL 的版本:

openssl version -v

升级系统可叁考 FNP: upgrade core system 或 FNP: upgrade major system。
升级完系统後,再进行一次 OpenSSL 版本之确认。
然後再安装该套件,这讯息就不会出现了。

第二种:使该套件相依於 ports tree 中的 OpenSSL
这种方法会安装 ports tree 中新版本的 OpenSSL,然後相依於此新版本的OpenSSL,而不是系统本身内建的 OpenSSL。只要安装套件时,加入 WITH_OPENSSL_PORT 的叁数,即会安装 ports tree 中的 OpenSSL,并且该套件也会相依於此。方法如下:

make -DWITH_OPENSSL_PORT install

这里不建议用叁数 WITH_OPENSSL_BASE,因为这表示安装套件时,是相依於原本
系统中可能有漏洞的 OpenSSL,这样会导致安全性的问题。

39、如何在 FreeBSD 上模拟 Linux 的环境?

最新最完整的资料在官方的 Handbook 上。
简单来说,FreeBSD 核心必须支援,且必须安装 Linux Runtime Libraries,最後做一些设定。
如果要执行 Linux ELF Binaries,可以先查询目前 FreeBSD 是否已经支援 Linux ELF。

brandelf -l

看是否有 Linux 的字样,如果没的话,请回头检查是否哪一步骤没有做到。
然後检查执行档是否为 Linux ELF Binaries。

brandelf execution-binary-filename

如果是 Linux ELF Binaries,则正常执行即可。
如果显示结果不是 Linux ELF Binaries,但是自己确定是 Linux ELF Binaries的话,则只要更改一下 ELF 的格式即可。

brandelf -t Linux execution-binary-filename

然後再检查一次是否已经修正为正确的格式。

40、如何在 FreeBSD 上安装 Linux rpm?

请确定已经成功在 FreeBSD 上模拟 Linux 的环境,请叁考 FAQ 39。
安装 rpm 的方式如下:

rpm –ignoreos –root /compat/linux –dbpath /var/lib/rpm/ -Uvh xxx.rpm

41、安装 ports 时,原本应该出现的清单选项不见了

这是由於系统会纪录曾安装过 ports 的当时所选择的清单选项,因此有时会因为安装时出了问题,或是再一次安装时,就不会出现清单可以选择。如何让清单选项重新出现呢?

make clean
make showconfig # 显示设定的内容
make rmconfig # 清除设定的内容
make config

之前设定 ports 的选项预设会纪录在 /var/db/ports/{ports_name}/options 内
容中。如要查看之前 python 有选择的清单选项:

cat /var/db/ports/python/options

42、如何检查是否有安装重覆的 ports/packages?

随着时间的演进,不同时间安装的软体会有不同版本的释出,而且不同软体相依的版本号也不同,所以往往会造成同一个软体安装过多版本的情形发生。
这里我必须声明的是,虽然套件名称相同,可是可能没办法上下相容,因此造成有些软体必须依赖比较旧的版本,而有些软体必须依赖比较新的版本,如果有这种情形发生的话,那麽二个版本的存在是正常的。

否则的话,我们会建议移除旧版的套件,将所有相依於此套件改为相依於新版的。也就是说,移除旧版的套件,然後将原本相依於旧版的套件,改为相依於新版的套件。注意,我强调的是新旧版套件是相容的。因为这种做法有点危险,因此不提供做法,请使用更水阶的套件管理工具,如 portupgrade 来完成。

检查是否有安装重覆的 ports/packages 的方法如下:

pkg_info | sort | sed -e ‘s/-[0-9].*$//’ | uniq -c | grep -v ‘^[[:space:]]*1’

如果有一行是显示” 3 libtool”,则表示目前系统有安装三种不同版本的libtool套件。
接下来可以检查这三种版本是否可以相容:

cd /usr/ports/
make search name=libtool

如果发现分别有三种 ports 来代表这三种不同版本的 libtool,就表示他们彼此不相容,必须保留三者,否则可能会发生相依问题。假设如下:

/usr/ports/devel/libtool13
/usr/ports/devel/libtool14
/usr/ports/devel/libtool15

反之,如果发现只有一种 ports 来代表这种不同版本的套件,则表示目前系统安装的三种版本是相容的,只要修改原本相容於其它二种版本所有的套件,并指向欲保留的那个版本,然後移除其它二种即可。如发现系统目前有安装三种不同版本的 gettext:

cd /usr/ports/
make search name=gettext

然後检查的结果如下:

/usr/ports/devel/gettext

则将所有相依於 gettext 旧版本的其它套件都改为相依於新版的 gettext,然後再移除系统中旧版的 gettext 即可。

43、`make deinstall’ 与 `pkg_delete’ 有什麽不同?

简单来说,`make deinstall’ 会移除该 port,并且不会叁照其相依/相关的 ports。
`pkg_delete’ 在移除该 port 前,会叁照其相依/相关的 ports,并且 `pkg_delete’有支援 wild card,如要移除所有 p 开头的 ports,则:

cd /var/db/pkg/
pkg_delete p*

[color=red]要注意的是,如果使用 `make deinstall’,则最好确定系统目前所安装的版本,与 ports collection 中显示的版本符合,否则有可能会出现非预期性错误;而 `pkg_delete’ 是因为直接删除系统中所安装的版本,所以没有此问题。

因此,换句话说,当系统所安装的版本符合 ports collections 中的版本,则可以使用 `make deinstall’ 或`pkg_delete’,否则的话最好用 `pkg_delete’。

与 `make deinstall’ 相关的资讯:FAQ 11、FAQ 12及FAQ 13。
与 `pkg_delete’ 相关的资讯:FAQ 11、FAQ 12及FAQ 15。

44、安装 ports 出现 local modification time does not match remote 的错误讯息

这通常表示你已经下载了这个档案在 /usr/ports/distfiles 的对应目录中,但是它并不是 port collections 所期望下载的。通常的解决方法是在 /usr/ports/distfiles 的对应目录中移除此档案,再重新抓取。

例如是安装 joe 时出现如下的错误讯息:
fetch: joe2.8.tar.Z: local modification time does not match remote

则将 joe2.8.tar.Z 於 /usr/ports/distfiles 中移除:

cd /usr/ports/editors/joe/
make distclean

最後再重新安装即可

Copyright © 2003, Tzeng, Yi-Feng.
All Rights Reserved.

原文链接:http://www.freebsdchina.org/forum/viewtopic.php?t=14435

Ports的make参数说明

FreeBSD::ports::make参数说明,哈哈,很多地方都用到哦

make fetch # 只抓取软件包
make extract # 只解开软件包
make patch # 解开软件包并补上官方的patch
make install # 安装一个新port
make clean # 清除中间生成的文件
make package # 将安装完的软件做成package
make distclean # 全部删除,包括/usr/ports/distfiles下的源码包
make all-depends-list  # 显示所有相关的依赖
make pretty-print-build-depends-list  # 显示编译期间所需要的依赖
make pretty-print-run-depends-list  # 显示执行时需要的依赖
make deinstall # 删除软件
make deinstall-depends # 连同依赖一起删除
pkg_version -c # 列出所有可升级的ports
make PREFIX=/usr/local/XXX # 指定一个安装路径
make showconfig make rmconfig
make search key=XXXX # 查找ports
make index # 更新index
make fetchindex # 更新index
make readmes # 网页的方式察看

原文链接:http://ray.bsdart.org/archives/166.raymond

使用FreeBSD默认的csh替代bash

使用FreeBSD默认的csh替代bash

一直以来,都习惯了bash的风格,比如命令补全、历史命令编辑、nohup后台运行,等等。

现在基本上只使用FreeBSD,而FreeBSD默认的shell并不是bash,而且bash ports是安装在/usr/local/bin/bash的,我一般都把/usr/local从根分区分离出去,这样的话,如果系统有问题需要进入单用户模式的时候,bash是不可用的。

研究了一下,如果csh经过一定的设置,也是很好用的。

1、设置命令补全,修改/etc/csh.cshrc文件:
set autolist

2、显示类似 [dirk@trinity /usr/local/etc]# 这样的提示符,修改/etc/csh.cshrc文件:
set prompt = ‘[%B%n@%m%b %B%~%b%]#’

3、让ls命令显示目录的时候带/斜杠区分普通文件,修改/etc/csh.cshrc文件:
alias ls ls -F

4、让csh具有历史命令编辑功能,还是/etc/csh.cshrc文件:
bindkey “^W” backward-delete-word
bindkey -k up history-search-backward
bindkey -k down history-search-forward

5、最后,使用script命令替代nohup命令:
script -a script.log “command”

原文链接:http://www.dirk.pdx.cn/blog/diary,266894.html