Solaris新手必读-121个问题解答

更新时间:2024-03-24 19:56:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

Solaris新手必读

-121个问题解答让你从菜鸟到高手

1. Q: Solaris 的系统配置文件一般在什么地方?

A: 可以查看/etc/system文件,里面有一些solaris启动时默认加载的选项,包括 共享内存大小等的设置。

2. Q: 在solaris中,用户默认的Shell在什么文件中规定? A: 可以查看/etc/passwd中,用户默认的shell在这里规定。 3. Q: 如果solaris不幸忘记了root密码,如何解决? A: 可以有如下两种情况

1. 工作站只有root用户,无其他用户。 2. 工作站除了root用户以外,还有其他的用户

1. 如果连接了网络,我们可以采用远程缓冲溢出的方法,但是这样的方法不属 于\经典\方法,且有的远程缓冲溢出具有一定的破坏性,不建议使用。还 有一种方法就是采用SUN公司自带的光盘采取引导,建议采取这种方法: 1. boot cdrom -s

2. fsck /dev/dsk/c0t0d0s0 (取决于根分区的设备) 3. mount -F ufs /dev/dsk/c0t0d0s0 /mnt 4. TERM=ansi; export TERM

5. 编辑/mnt/etc shadow文件,把root对应的口令去掉。 6. 重启后的root的口令为空。

2. 如果还有普通用户,方法可以采用本地缓冲溢出,这种方法虽然破坏性小, 但是也有损毁硬盘引导区的危险,建议采用\文件连接\错误是获得root权 限,这种方法没有什么危险性。

4. Q: 有时候用vi编辑器的时候,显示窗口过大,如何处理? A: 只需要用鼠标拖曳终端窗口,使其缩小,即可解决。

5. Q: 共享内存大小如何设置?

A: 在system文件的最后一行加入Set shmsys:shminfo_shmmax=XXX /etc/set shmsys:shminfo_shmmin=XXX

这里的XXX是代表共享内存的大小。单位:字节 共享内存一般为内存的一半 例如内存为512M

设置应为512/2*1024*1000=262144000 6. Q: root用户的配置文件在什么地方?

A: root用户的配置文件和其他用户的配置文件有些不同,它在/etc/profile文件 中规定。

7. Q: SUN solaris 在远程X-win pro下无法以root进行登陆,如何解决? A: 直接以root在终端上登录的时候,执行/etc/default/login脚本。在这个脚本 中限制了在远程终端上不能直接以用户root登录,如果想这样,修改此脚本, 将下面这一行注释掉即可 CONSOLE=/dev/console

8. Q: 在solaris下,如何查看网络是否配置成功?

A: 可以采用命令Ifconfig -a来查看,如果网卡绑定ip成功,而不是显示0.0.0.0 就证明网卡配置基本无误,主要检查网络介质(网线,RJ45插头...)是否损坏。 9. Q: 如果敲错一个命令如何结束它呢?

A: solaris和SCO有少许不一样,solaris可以采用ctrl+C来结束,而不是SCO的 ctrl+Del

10.Q: solaris的联网中,网关如何配置? A: solaris的网关设置和SCO的设置不一样 SCO:

/etc/gateways

; name1 gateway name2 metric value ; 所有中间的很长的空均为TAB

Net,host 表示路由指向是网络还是主机,net和host是关键字 Name1 目的网络名或主机名 Gateway 关键字

Name2 网关名或网关ip地址 Metric 关键字 Value 跳数

Passive 关键字,表示被动方式,路由器不叫换路由信息 Active 关键字,表示主动方式,路由器交换路由信息 External 关键字,表示外部方式,其他进程已安装了路由 例如:

net 129.9 gateways 129.6.0.1 metric 1 passive host 129.7.10.21 gateway 129.6.0.2 metric 1 passive Solaris

为defautrouter,只需要在里面填入网关。 11.Q: 如何在网上安装Solaris?

A: 假设SERVER IP为10.11.41.10,hostname为inssvr;CLIENT IP为10.11.41.11 ,hostname为inscli。 在SERVER端执行以下步骤 条件:有340M的剩余空间

1. 将Solaris 2.6的安装盘插入CD-ROM 2. 将Solaris 2.6 CD-ROM的slice 0拷贝到硬盘 # cd /cdrom/sol_2_6_sparc_smcc_svr/s0/solaris_2.6/Tools # ./setup_install_server /export/install

3. 编辑文件/export/autocfg/sysidcfg,以下是它的内容 #Sample sysidcfg file for SPARC systems system_locale=en_US timezone=GMT-8 timeserver=10.11.41.10 terminal=dtterm

name_service=NONE

root_password=...(取自/etc/shadow文件) 4. 编辑文件/etc/hosts,以下是它的内容 10.11.41.10 inssvr loghost 10.11.41.11 inscli 5. 增加安装客户 # cd /export/install

#./add_install_client -e CLIENT的以太网地址 -i CLIENT的IP地址 -s

inssvr:/export/install -c inssvr:/export/autocfg -p inssvr:/export/autocfg inscli sun4u 在CLIENT端的OK提示符下执行 OK boot net - install

Solaris 7 for sparc与2.6的区别,7没有默认的sysidcfg和autocfg目录,需要自 己建立,而且OK boot net即可 12.Q: DHCP in Solaris8?

A: 1. # touch /etc/dhcp.hme0,hme0:请用相应的网卡设备名; 2. 修改/etc/init.d/network,/etc/init.d/inetsvc 先备份

# cp /etc/init.d/network /etc/init.d/network.org # cp /etc/init.d/inetsvc /etc/init.d/inetsvc.org 修改/etc/init.d/network第278行:

\hostname=`cat /etc/nodename` 修改/etc/init.d/inetsvc第168行: hostname=`/sbin/dhcpinfo Hostname` if [ -z \#hostname=\

hostname=`cat /etc/nodename` fi

修改/etc/init.d/inetsvc第82行:

if [ \#dnsdomain=`/sbin/dhcpinfo DNSdmain` dnsdomain=`cat /etc/defaultdomain` else dnsdomain= fi

if [ -n \

#dnsservers=`/sbin/dhcpinfo DNSserv` dnsservers=`cat /etc/dnsservers` 修改/etc/init.d/inetsvc第220行:

/usr/bin/mv /tmp/hosts_clear.$$ /tmp/hosts.$$ mydomain=`cat /etc/defaultdomain`

echo \>;>;/tmp/hosts.$$

在/etc/init.d/inetsvc第一行加入如下语句: if [ -f /etc/dhcp.*[0-9] ]; then _INIT_NET_STRATEGY=\export _INIT_NET_STRATEGY fi

3. 创建/etc/defaultdomain,内容为huawei.com.cn 4. 创建/etc/nodename,内容为你的机器名 5. 创建/etc/dnsservers:129.9.111.100 10.15.1.3

之所以要修改,究其原因我们的DHCP服务器支持的协议可能比较老,不能返回给 客户端DNSdomain,DNSServer,Nodename; 13. Q:SUN上如何编译动态库? A:

CC=cc C++=CC +w .SUFFIXES:.cpp .cpp.o:

$(C++) -g -c -Kpic $< liberrlog.so:ErrLog.o

ld -o liberrlog.so -G ErrLog.o

14. Q: 在sun工作站上安装solaris软件时没有安装网卡,安装完成后应该修改那些文 件添加网卡? A:

1. #reboot --r 或者ok boot -r

2. 在1.成功找到你新加的硬件之后,再执行相应的硬件设置命令,对网卡执行: ifconfig hme0 ; [ipmask],其中hme0是你网卡的设备名,可以通过dmesg知 道你的网卡设备名. 15. Q: 如何设置DNS?

A: (1)/etc/nsswitch.conf的hosts解析加上nis或/和dns,内容如下 hosts: files dns

(2)设置到DNS服务器网关于/etc/defaultrouter,内容如下 10.11.43.254

(3)设置DNS服务器的IP地址/etc/resolv.conf,内容如下 nameserver 10.15.1.3 nameserver 129.9.111.100 domain huawei.com

16. Q: Ultra60工作站从外挂光驱启动?

A: Ultra60 工作站缺省配置是内置光驱,用外挂光驱重新安装Solars时,用boot cdrom命令则不能从光驱启动,屏幕上打印错误信息:Drive not found. 原因如下:由于Ultra60工作站缺省支持内置光驱,cdrom的缺省配置是内置光

驱的物理设备名。当使用外挂光驱时,当使用boot cdrom命令时,cdrom的替 换为内置光驱的物理设备名。这就是不能从光驱启动的原因。 解决办法如下: (1)stop+a命令

(2)在ok提示符下输入:probe-scsi-all

则出现硬盘、光驱、磁带机等设备的实际物理名。 如:/pci@1f,4000/scsi@3,1 cdrom

(3)在ok提示符下输入:devalias

则出现硬盘、光驱、磁带机等设备的缺省设置。 如:cdrom /pci@1f,4000/scsi@3/disk6,0:f

这是缺省配置,用boot cdorm命令时,cdrom被解释为 /pci@1f,4000/scsi@3/disk6,0:f

而/pci@1f,4000/scsi@3/disk6,0:f指示的是内置光驱的设备名, 因此不能从外挂光驱启动!

(4)在ok提示符下输入:boot /pci@1f,4000/scsi@3,1/disk6,0:f

说明:[boot后的参数参看(2)和(3)中的cdrom的设备名,由两者组合而来 即可正确的从外挂光驱启动。

17. Q: 一台Sun Ultra80工作站安装SunOS 5.6失败,请问其原因以及如何避免? A: 硬件环境为Ultra-80/2CPU(450M)/1harddisk(18G)/2G Memory,从网络启动安 装SunOS 5.6。安装过程中途中断并出现以下提示:

panic[CPU3]/thread=0x301bde80: CPU3 privileged UE Error: AFSR 0x00000000 80200000

AFAR 0x00000000 7c5e0190 SIMM U1302 U0302 U1301 U0301 syning file systems... [27[ 406 136 done 12535 static and sysmap kernel pages 50 dynamic kernel data pages 205 kernel pageable pages

0 segkmap kernel pages 0 segvn kernel pages 0 current user process pages 12790 total pages (12790 chunks) dumping to vp 6145608c, offset: 3989467

panic[CPU3]/thread=0x30043e80: panic dump timeout Dump Aborted

Type 'go' to resume{3} ok

随后输入'go'或者'boot -r'都无法使系统启动,提示如下: Can not open Kernel/unix input filename [Kernel/unix]:

只有重新从网络启动。这是由于CPU硬件结构与Solaris系统不兹容造成的, 需要补丁。这个问题不仅仅是在Ultra80的机器上,如果Ultra60使用了SUN的 新推出的高速CPU(400M以上,一般为450M)且操作系统为Solaris 2.6或者 Solaris 2.5.1,也会出现类似问题。如果工作站使用的是这种高速CPU,在 随新机器一起的附件中会有一本手册:Installing Solaris 2.5.1 or Solaris 2.6 Software on 419+ MHz Systems,其中详细描述了如何解决这 个问题(在zh-6页)。另外,附件中还有一张补丁光盘,名字叫做: Operating Environment Installation CD May 1999,此光盘专门用于解决 此问题.

18. Q :在solaris上如何进行数据的备份和恢复?

A: 备份整个文件系统,也称作完全备份(full dump);在完全备份的基础上备 份修改过的文件,称作渐进备份(incremental dump); ufsdump

ufsdump命令用于备份文件系统,可以完全备份也可以渐进备份。ufsdump命令的格式 为:/usr/sbin/ufsdump [options] dump_device files_to_dump options包括:

0-9:指定备份的级别。0为最低,即完全备份;9为最高。假设当前备份级别为i,那 么ufsdump命令在执行时将寻找最近一次级别等于i或小于i的备份,将以前备份过后修

改过的文件备份下来。例如,星期一执行了一次级别为2的备份, 星期二执行了一次 级别为4的备份,那么当星期三执行级别为3的备份时备份文件中将包括自星期一备份

以来所有修改过或新创建的文件。如果星期三执行级别为4的备份,那么备份文件中将

包括自星期二备份以来所有修改过或新创建的文件。 f:指定备份的设备,例如/dev/rmt/0;

u:更新备份记录(/etc/dumpdates)。使用这一选项后ufsdump将创建或更新 /etc/dumpdates文件,文件内容包括文件系统名、备份级别、和备份时间,例如: pioneer# ufsdump 0uf /tmp/ddd /dev/dsk/c0t0d0s0 DUMP: Writing 32 Kilobyte records

DUMP: Date of this level 0 dump: Mon Sep 07 22:37:16 1998 DUMP: Date of last level 0 dump: the epoch

DUMP: Dumping /dev/rdsk/c0t0d0s0 (pioneer:/) to /tmp/ddd. DUMP: Mapping (Pass I) [regular files] DUMP: Mapping (Pass II) [directories] DUMP: Estimated 25234 blocks (12.32MB). DUMP: Dumping (Pass III) [directories] DUMP: Dumping (Pass IV) [regular files]

DUMP: 25214 blocks (12.31MB) on 1 volume at 1599 KB/sec DUMP: DUMP IS DONE

DUMP: Level 0 dump on Mon Sep 07 22:37:16 1998 pioneer# more /etc/dumpdates

/dev/rdsk/c0t0d0s0 0 Mon Sep 7 22:37:16 1998 备份前的准备工作

重新启动系统到单用户状态,或将要备份的文件系统卸载下来。 通知所有用户该文件系统不可用。

#wall

/export/home will be unavailable in two minutes, please log out Press ctrl-D

对文件系统进行检查(fsck)。 ufsdump 如前例所示。

如果使用渐进的备份方法,最后实现建立备份计划,例如: Sun Mon Tue Wed Thu Fri Week1: Full 5 5 5 5 3 Week2: 5 5 5 5 3 Week3: 5 5 5 5 3 Week4: 5 5 5 5 3

上例中,每个月作一次完全备份,每个周末对每一周的改动作一次备份,每天的备份 只对当天的改动作备份。这样作的目的是节省备份所用的空间。 ufsrestore

ufsrestore用于恢复使用ufsdump命令备份的文件系统。命令格式为: /usr/lib/fs/ufs/ufsrestore options [arguments] [filename ...] options包括: t:备份列表;

x:只恢复命令行中指定的文件; r:恢复整个备份;

f:指定备份文件所在的设备或目录; v:verbose mode,列出备份文件的路径。 例如:

对备份文件进行列表: pioneer# ufsrestore tvf ddd Verify volume and initialize maps

Media block size is 126 Extract directories from tape Initialize symbol table.

Dump date: Mon Sep 07 22:37:16 1998 Dumped from: the epoch

Level 0 dump of / on pioneer:/dev/dsk/c0t0d0s0 Label: none dir 2 .

dir 3 ./lost+found dir 5696 ./usr dir 11392 ./var dir 5697 ./export dir 11393 ./export/home dir 5698 ./opt leaf 4 ./bin dir 11394 ./dev dir 5699 ./dev/sad leaf 5879 ./dev/sad/admin leaf 5825 ./dev/sad/user leaf 11592 ./dev/be leaf 11496 ./dev/conslog ...

从备份中恢复指定文件: pioneer# cd /tmp

pioneer# ufsrestore xvf ddd ./etc/passwd Verify volume and initialize maps Media block size is 126

Dump date: Mon Sep 07 22:37:16 1998 Dumped from: the epoch

Level 0 dump of / on pioneer:/dev/dsk/c0t0d0s0 Label: none

Extract directories from tape Initialize symbol table. Make node ./etc Extract requested files

You have not read any volumes yet.

Unless you know which volume your file(s) are on you should start with the last volume and work towards the first. Specify next volume #: 1 extract file ./etc/passwd Add links

Set directory mode, owner, and times. set owner/mode for '.'? [yn] n

执行该操作需要指定所要恢复的文件在备份文件中的位置。由于备份文件从卷1开始,

所以可以指定从卷1开始搜索。恢复整个文件系统下例将一个老的文件系统(/opt)移 到一个新的磁盘分区(/dev/rdsk/c0t3d0s5)中。首先,卸载老的文件系统并实施备 份:

#umount /opt #fsck /opt

#ufsdump 0uf /dev/rmt/0 /opt

其次,生成新的文件系统,将其安装到一个临时目录(/mnt),并实施恢复: #newfs /dev/rdsk/c0t3d0s5 #fsck /dev/rdsk/c0t3d0s5 #mount /dev/dsk/c0t3d0s5 /mnt #cd /mnt

#ufsrestore rvf /dev/rmt/0 #rm restoresymtable

最后,卸载新的文件系统,用fsck检查其一致性。 #cd / umount /mnt #fsck /dev/rdsk/c0t3d0s5

选择性备份,备份指定的文件和目录; tar

系统备份:tar -cvf 目标文件名/设备名 备份文件,例如: tar -cvf backup.tar *

命令将当前目录下的所有文件(包括各级子目录)都打包在backup.tar文件中。 tar -cvf /dev/rmt/0 *

命令将当前目录下的所有文件(包括各级子目录)都打包到磁带上。查看tar文件的内 容:tar tvf 目标文件名/设备名,例如: tar -tvf backup.tar tar -tvf /dev/rmt/0

将tar文件中的内容恢复到指定目录中去:tar xvf 目标文件名/设备名 [目录名],例 如:

tar -xvf backup.tar /home tar -xvf /dev/rmt/0 /home

如果不指定目录名则表示当前目录。 19. Q: 如何在Soraris下面安装ATM网卡? A: 网卡型号:FORE PCA-200EUX/OC3 操作系统:Solaris 2.7 工作站:SUN Ultra60 一、硬件安装

1、工作站关电后,将网卡妥善安装在一个PCI插槽中;

2、工作站上电,按STOP and A中断boot process,到ok提示符;

3、输入命令show-devs,显示系统配置,FORE网卡的device-pathname应出现在 配置列表中,形式可能如下: /pci@1f,2000/FORE,PCA-200E@2

4、设备提供光口自环测试(media loopback)和内部自环测试(internal loopback), 供检查设备及安装是否完好。根据经验用内部自环测试即可,方法: 输入命令 test /pci@1f,2000/FORE,PCA-200E@2

待出现:pass 0 说明硬件及安装都正确; 5、输入boot命令 ,启动系统。 二、软件安装

1、软件安装需要root权限;

2、网卡支撑软件一般是一个.tar文件提供,解开后在其目录下有8个子目录,分 别为:

FORECore ForeThought ATM Core Software FOREDrv ForeThought ATM Card Drivers

FORESpans ForeThought SPANS Signalling Software FOREUni ForeThought UNI Signalling Software FOREclip ForeThought Classical IP Software FOREip ForeThought FORE IP Software

FOREmpoa ForeThought MPOA / LAN Emulation Software FORExti ForeThought XTI Application Programming Interface

3、例如.tar文件解开后在/home/FORE下,则该目录下就有上述8个子目录,我们要 用的程序在FOREDrv、FOREip下,但各个模块之间有一定的依赖关系,需要安装的模块

有6个: FORECore、FORESpans、FOREDrv、FOREip、FOREUni、FOREclip。安装过程: >; pkgadd -d /home/FORE

The following packages are available:

1 FORECore ForeThought ATM Core Software .........(sparc) 5.1

2 FOREDrv ForeThought ATM Card Drivers .........(sparc) 5.1

3 FORESpans ForeThought SPANS Signalling Software .........(sparc) 5.1

4 FOREUni ForeThought UNI Signalling Software .........(sparc) 5.1

5 FOREclip ForeThought Classical IP Software .........(sparc) 5.1

6 FOREip ForeThought FORE IP Software .........(sparc) 5.1

7 FOREmpoa ForeThought MPOA / LAN Emulation Software .........(sparc) 5.1

8 FORExti ForeThought XTI Application Programming Interface Select package(s) you wish to process (or 'all' to process all packages). (default: all) [?,??,q]:

选择要安装的模块,根据提示安装。

4、安装后的软件在/opt/FOREatm /bin (使用的配置命令所在目录) /conf /examples /include /lib /man 三、网卡配置 1、网络接口名配置 >;configure_atm

选择配置ip模块,得到一个ip interface名,默认为fa0。重启工作站,可以看到在 /dev下有fa0接口,而网卡的设备名为fatm0。 2、>;adinfo fatm0 可查询设备硬件信息 >;adconfig fatm0 可进行设备配置 >;adstat fatm0 可查询设备状态 这三个命令较少用到。 3、接口ip地址配置

ifconfig fa0 ; netmask ; broadcast ; up 4、IPOA配置

atmarp -s hostname device vpi vci aal encapsulation(outgoing PVC配置) atmarp -l device vpi vci aal encapsulation (incoming PVC配置) 例:分配给工作站的pvc为 vpi 0 vci 150 工作站的IPOA地址为200.200.200.101

42 Q: /etc/system 文件中的namespace指的是什么,与Modules有何关系?system文 件中哪些参数将对机器性能有较大影响?

A: 所有的手册都警告说修改system文件应当慎重,事实上,也只有在安装数据库, 增加新的设备时,才有可能需要修改此文件.所改的参数,也就是你附件中改过的 那几个线程数,信号量之类的. 修改参数值,会影响整个系统的开销,因为这些值 所涉及的空间分配是在系统启动时进行的namespace用于对modules分类, 说明 中指出了目前支持的几种namespace,用户不能增加新的种类.

43 Q: I am a programer work with SUN C++. Can I use STL(stand template library) in program. I can't find any help in SUN C++'s document.Thank you.

A: Sun 的 C/C++ WorkShop 中的C++ 类库好像包含 STL, 可以参考一下. docs.sun.com 上有完整的文档,可以参考一下.

44 Q: 原来的系统中/usr与 / 在同一个硬盘分区上,由于安装了许多软件,此分区已满 ,现在系统增加了硬盘,如何将/usr 目录挪到新的硬盘上? A: 1.在新的硬盘上将文件系统建好, 2.mv /usr /usr.bak 3.mkdir /usr

4.mount newdriverpath /usr 5.cp -r /usr.bak /usr 6.修改/etc/vfstab 文件.

45 Q: 运行下面这段程序并用vmstat观察内存的使用情况: int main(){ int *p[100]; int c;

printf(\c=getc(stdin); for(int i=0;i<100;i++)

p=(int *)malloc(sizeof(int)*32000); printf(\

//1..... c=getc(stdin); for(int i=0;i<100;i++) free((void *)p); printf(\//2...... c=getc(stdin); return 0; }

发现在 2 处系统的空闲内存块并没有增加,free调用到底有没有释放内存? A: malloc 调用引起进程堆空间增长,但free调用不会导致该堆空间立即缩小, 系统只是简单记录这一变化,就继续运行程序,只有系统出现内存短缺时, 系统才收集这些内存块重新分配,这样实现是为了减少系统开销,提高效率.

46 Q: 请问在kstat的输出中,类似avenrun_15min这种内核动态参数有没有介绍材料? A: 通常, kstat输出的是内核模块中的一些链表或数组,按照SUN公司的文档,这些 输出结果是自解释型的,根据他们的名字就可以猜到其含义.但实际上并不是这 样.这些链表中包含的结构是在;下的一些头文件中定义的,比如

kmem_cache模块的结构由kmem_impl.h定义,hme模块的结构由hme.h定义,等等. 翻看这些头文件,可以得到稍微详细一点的资料. 参数名字通常与某结构的成员 变量同名,头文件中由简单的注释指出其作用. 比如:hme模块输出中包含如下字 段:

brdcstrcv 1094670

我们就可以查hme.h,hme.h中有一个很大的结构:hme, 其中有: uint32_t hme_brdcstrcv; /* # broadcast packets received */

47 Q: 1.问题描述:Router&LanSwitch的日志管理依赖系统的syslogd进程来实现。 通过设置/etc/syslog.conf文件, 可以控制syslogd把日志存入特定的文本 文件中。然后日志后台就可以周期性的轮询这些文件并导入数据库。按照sun 的man页说明,当向syslogd进程发HUP信号时,进程将重读配置文件 /etc/syslog.conf,然后继续运行。 但在Solaris2.7以下实际的效果是:发 HUP信号将导致syslogd进程不能正常工作(有的试验结果是,信号导致进程

终止),后续设备日志全部丢失。 2.解决建议:

我们的建议是,修改系统的脚本文件/usr/lib/newsyslog,不让其向syslogd 发HUP信号,而是TERM(终止信号),然后重启。此种方法的弊端是,如果用 户主动向进程发HUP信号,仍然存在问题。而且也不能解决syslogd意外退出 的情况。第二种建议是由综合统一做一个检测进程,这样各项目就不会产生 冲突。但仍然存在用户主动向进程发HUP信号使syslogd失效的问题。由上述 可以看出,无论何种方法,都不能彻底解决问题。

A: 问题的产生可能是由于程序员定义了新的日志文件并企图 使用newsyslog 脚 本来处理,这个脚本备份日志文件再发送 HUP信号。newsyslog 脚本在处理系 统文件时不会有问题,很可能是由于syslogd对这些文件做过专门的处理。但 不能认为我们自己的文件也会得到同样的照顾,事实上,这样做通常是危险 的。 我认为建议2 是可行的, 因syslogd打开的是新的日志文件,不会发 生异常。而用户发送的 HUP 命令只是使 syslogd重读 syslog.conf 文件 ,也不会发生意外.为了比较好的定位问题,建议在一个比较干净的系统上进 行测试,在测试之前最好停掉自己的程序, 简化/etc/syslog.conf,我是这样测试的: # /usr/lib/newsyslog

# logger -p deamon.notice \# cat /var/adm/messages # kill -HUP `cat /etc/syslog.id` # logger -p deamon.notice \# cat /var/adm/messages 结果正常.

48 Q: Solaris 8中,为什么不可以用如下命令给网卡增加逻辑地址? ifconfig hme0:1 xxx.xxx.xxx.xxx up

A: Solaris 8 对ifconfig 作了一些改动,在这个命令之前,先执行下面的命令就可 以了: ifconfig hme0:1 plumb

49 Q: 为什么Solaris 中的多个网卡显示的以太网地址都是一样的?

A: 缺省情况下,系统使用本机的MAC地址作为各网卡的MAC地址,可以用如下 OpenBoot 命令让系统使用网卡自带的MAC地址. ok setenv local-mac-address? true

50 Q: 如何在一台机器里如何实现用多块网卡容错?

A: Solaris8 新增了一个daemon叫mpathd将网卡管理分组管理来完成这样的功能. 原理是给每个网卡分配两个地址,多出的一个逻辑IP地址由mpathd用来检查个网 卡的工作情况.下面一两块网卡为例介绍配置过程,这里两块网卡分别是hme0和 hme1,

1. ifconfig hme0 group test ifconfig hme1 group test

2. ifconfig hme0 addif 19.16.85.21 netmask + broadcast + -failover deprecated up ifconfig hme1 addif 19.16.85.22 netmask + broadcast + -failover deprecated up 3. 检查hme0:1和hme1:1看是否有逻辑IP ifconfig hme0:1 ifconfig hme1:1

这里要注意,给网卡增加的逻辑IP应当与实际分配的IP地址在同一个网段并 且不能与网上其他主机IP地址冲突. 51 Q: 一个进程里最多可以打开多少文件?

A: 操作系统为每个进程维护一个所打开文件的数组,进程能够打开的文件与此数组 的大小有关.此数组的大小由两个系统变量限制: rlim_fd_max , rlim_fd_cur, 这两个变量可以用limit或ulimit 命令察看和修改,要扩大rlim_fd_max需要 root权限,rlim_fd_cur不能超过rlim_fd_max. 编程时则有库函数 getrlimit 和 setrlimit 可以使用. 另外一种改法是在 /etc/system文件中修改. 如果是 调用stdio函数打开文件,则还有另外一种限制,32位内核Solaris 的 FILE 结构 中的 文件句柄是一个字节,所以同时打开文件的上限是256 52 Q: 如何改变登录CDE时的语言环境?

A: 修改/usr/dt/config/Xconfig文件中的变量 Dtlogin*language即可.

53 Q: 如何防止用户通过CDE 环境中的 suspend 菜单关闭计算机? A: 修改 /usr/openwin/bin/sys-suspend的执行权限就可以了.

54 Q: 我安装完solaris5.7之后(安装时选择简体中文),运行C语言编译器cc不成功 ,提示\。请问这是 怎么回事,该如何解决?

A: Solaris本身带有adb,mdb,make工具,但不带C语言编译器.若要使用需要单独购 买软件包及license.

55 Q: 想修改ROOT的缺省PATH,在哪改?不要告诉我LOCAL.PROFILE,不管用. A: 如果以root用户身份登录或者用 su - 命令进行切换,则修改 home目录下 .profile是管用的. 如果是简单的 用 su 进行切换, 则系统保留除 PATH之外 的所有环境变量, PATH被设为 /etc/default/su 中的 SUPATH ,缺省时为 /usr/sbin:/usr/bin

56 Q: 问一下,现在在Solaris下有什么比较好的测试程序语句以及条件覆盖率的工具 A: prof 和 gprof 都有. 如果您使用workshop 或者 Forte 6.0,则其中有 performence analysis tools 可以使用.

57 Q: 怎么样让系统启动时就自动在一个网卡上绑定两个IP地址 A: 创建文件 /etc/hostname.hme0:1,其中写上第二个ip地址.

58 Q: Sun solaris7系统中有一下几种SHELL,sh,csh,ksh,另外还有一个jsh. 我的问题是:jsh是什麽SHELL?另外有bash SHELL吗?

A: jsh 就是 sh, 只不过是激活了job control 模式. 但现在 sh 本身就有job control 功能,所以只用 sh 就可以了. bash 是 sh 的增强, 如果你的系统没 有这个shell, 可以到 www.sunfreeware.com 下载. ls /bin/*sh 可以看到系统所有存在的shell.

59 Q: 我的光驱无法读取光盘?且总是显示设备忙,如何搞定?mount显示没有被 mount.

A: 查找进程 vold 并将其杀死,就可以手工打开光驱.

60 Q: 如何将root用户的shell改掉,我知道一般用户可在admintool下修改,但root 用户不能。

A: 1. chmod 666 /etc/passwd (一定要让普通用户有些权限,切记!)

2. vi /etc/passwd(最后一个字段试root 的 shell,要确保该程序存在方可改 掉它. )

61 Q: 我在安装Solaris 8时启用了DHCP,现在我的主机名是unknown,在启动时工作 站启用DHCP并分配IP,主机名也自动改为unknow。请问怎样改主机名? A: DHCP in Solaris8

1. # touch /etc/dhcp.hme0,hme0:请用相应的网卡设备名; 2. 修改/etc/init.d/network,/etc/init.d/inetsvc 先备份

# cp /etc/init.d/network /etc/init.d/network.org # cp /etc/init.d/inetsvc /etc/init.d/inetsvc.org 修改/etc/init.d/network第278行:

\hostname=`cat /etc/nodename` 修改/etc/init.d/inetsvc第168行: hostname=`/sbin/dhcpinfo Hostname` if [ -z \#hostname=\

hostname=`cat /etc/nodename` fi

修改/etc/init.d/inetsvc第82行:

if [ \#dnsdomain=`/sbin/dhcpinfo DNSdmain` dnsdomain=`cat /etc/defaultdomain` else dnsdomain= fi

if [ -n \

#dnsservers=`/sbin/dhcpinfo DNSserv` dnsservers=`cat /etc/dnsservers` 修改/etc/init.d/inetsvc第220行:

/usr/bin/mv /tmp/hosts_clear.$$ /tmp/hosts.$$ mydomain=`cat /etc/defaultdomain`

echo \>;>;/tmp/hosts.$$

在/etc/init.d/inetsvc第一行加入如下语句: if [ -f /etc/dhcp.*[0-9] ]; then _INIT_NET_STRATEGY=\export _INIT_NET_STRATEGY fi

3.创建/etc/defaultdomain,内容为huawei.com.cn 4.创建/etc/nodename,内容为你的机器名 5.创建/etc/dnsservers:129.9.111.100 10.15.1.3 62 Q: 我用msgget建一消息队列:

ret = msgget(IPC_PRIVATE, (0660)|IPC_CREAT); 在一个线程用msgsnd发消息,另一个msgrcv收:

ulReturnCode = msgsnd( QueueID, pBufferAddr, 8 ,IPC_NOWAIT);

当消息队列中的消息个数等于40时(每个消息尺寸为8字节),msgsnd函数返 回-1,errno= 11,请问是什么原因。是消息队列满吗?怎样调整系统参数,使 消息队列能大些。

A: msgmap : 100 maximum size of resource map for messages msgmax : 2048 maximum size ,in byte, of a massages

msgmnb: 4096 maximum number of bytes on a message queue. msgmni: 50 maximum size of message queue identifiers. msgssi: 8 message segment size.

msgtql: 40 maximum number of message headers msgseg: 1024 maximum number of message segments. msgseg 最大为 32k, 其他参数最大值都是 2 billion.

63 Q: license server 如何启动?

A: run /opt/SUNWste/bin/lmgrd.ste 可启动 license server

64 Q: 在Solaris8下,如何修改一个目录的大小。安装时系统自动的设置 /export/home目录空间很大,而其他目录空间很小。 A: 1, 备份 /export/home, 2. umount /export/home, 3. 用 format 修改盘片大小, 4. 备份要增大的目录, 5, umount

5. 用 format 增加盘片大小. 6. 重新mount.

65 Q: 请问用什么命令可以确定是否有磁带设备?多谢。 A: 看一下 /dev/rmt 如果是空就没有. .

66 Q: 在solaris 8下安装Forte Developer 6 到达: installing Forte C++ Entep Ed 6/SPARC installing Forte Developer 6 时死掉应如何解决

A: 在安装之前,应当清除所有以前安装时添加进系统的package. 另外,不用缺省目录 /opt , 换一个新建的空目录也有效. 67 Q: Forte c/c++版本可以用在solaris2.6操作系统上吗? A: 可以

68 Q: 在输入用户名后启动很慢,有时甚至进不了,停在启动画面,不知如何解决(我用 过fsck,也不好使,有没有更好的办法)!能否重装操作系统,而不影响现有的已装 软件.谢谢!

A: 一般说来, 这与家目录下配置文件有关.新建一个用户试一试.

69 Q: 现在远程维护的解决方式是通过Modem拨号,建立连接,通过我们自己编写的IP

代理转发程序,完成对传输设备远程维护。在PC机上的拨号网络,拨号程序运 行都比较正常,对连接速度,稳定性方面目前使用还算可以。但是在设置Sun工 作站的拨号程序的时候,我常常会遇到一些\奇怪\的问题, 比如Modem不握 手,没有拨号音等。现在我们的拨号设置是自己编写的脚本文件方式。可能对 各种情况考虑的不全面,因此请问是否有相应的软件包(程序)可以帮助我们 机型拨号设置,保证拨号成功?

A. 连接失败通常与配置参数有关,由于硬件种类繁多,很难保证一个程序在所有的 硬件环境下都能顺利配置成功.我们只能针对具体情况进行分析.但我们发现,改 变串口的流倥方式经常有助于问题的解决.Sun solstice 中有一个拨号软件据 说比aspppd 更容易使用,我没有用过,或许您愿意试一试?

70 Q: 我这多线程程序,我用ftime得到函数的调用时间,发现在一个线程中,增加一 个printf后,调用时间为5毫秒。去掉这个printf,调用时间却为15毫秒。增加 了一个printf为什么后使该函数的执行更快了?

A: ftime 得到系统当前时间,但具体到线程的执行时间,是和系统的调度情况有关 的, 请用调试工具来检查准确的执行时间.

71 Q: 我们的技术支持人员遇到一个问题,向您请教:在安装时没有选择安装网络, 现在需要安装网络,怎样增加一个interface。目前只有lo0,没有hme0。 A: 在 /etc 下 touch 一个空文件 hostname.hme0, 用 boot -r 命令重起. 72 Q: 在Sun Ultra 5工作站(安装SOLARIS 2.6),每次开机时,都出现以下问题: Restoring the system.Please Wait ... cpr_read_bitmap:Can't cpr_alloc bitmap0

Can't read statefile bitmap,please reboot Program terminated {0} OK

每次开机都需要boot才能进入。 请问如何解决?

A: 首先, 在 ok 状态下检查 boot-file 参数: printenv boot-file

如果是 boot-file = -F cprboot 之类, 用如下命令: set-default boot-file 再检查一下.应该是空才对. 如果不是, 则需要设置: setenv boot-file -F ufsboot 重新启动.

73 Q: 经实验,两台Sun工作站之间通过网络发Syslog日志,也不支持汉字,该问题可 能是syslogd的问题。

A: 估计是由于syslogd在望上传输时丢掉了字节的最高位.

74 Q: 如果需要ID:105181-15的patch,请问ID:105181-19可以代替吗?ID毫最好两位 是不是patch的版本号,如果是版本号有没有前项兹容性? A: 可以, 后两位表示同一patch的版本号.

75 Q: 以下代码在Forte C++下导致编译错误,请问如何解决? template;

void testimpl(int i1, int i2, p1* n1 = 0, p2* n2 = 0) {

p1* pReq = new p1; p2* pRsp = new p2; }

void test() { int i = 0; int j = 0;

testimpl;( i, j); }

A: 请下载新的patch更新Forte C++

76 Q: 请问:如何设置工作站的最大客户端数?现有一台测试用机,使用人较多,经 常出现\无法得到pty\的提示。

A: 在/etc/system ,可以用参数 maxusers 设置,最大2048,如果这里没有设置,默 认为与系统内存容量相同(以M记,最大为1024), 77 Q: I install visibroker into my solaris 2.7.

When I execute a example program,it cannot execute and tell me: ld.so.1: Server: 致命的: liborb64r_so:打开失败:无此文件或目录 被杀掉

(Server is my program)

Can you tell me how to settle it?

A: you should set this envirnment variable: LD_LIBRARY_PATH 78 Q: 贵处有无磁带机的使用手册或指导说明? A: answerbook 中系统管理员手册 I 有使用说明.

answerbook 的文档不是html格式,需要一个服务器程序转换, 察看本机http进 程看有没有下面这个: # ps -ef |grep http

# /usr/lib/ab2/dweb/sunos5/bin/dwhttpd /usr/lib/ab2/dweb/data

79 Q: 在 solaris 2.5.1 上 把 系统时间 改为 2004 年,无问题,然后把时间再改回 来后,整个UNIX 死机,请SUN工程师答复. 具体操作为: 将操作系统时间设为 2004年3月1日,然后再将操作系统时间改回当前的时间,则系统的cpu资源被两个 进程dtwm,dtfile严重占用,X Window反应非常缓慢,在低配置的系统上导致系统 不可操作.同时显示 \

A: 在窗口环境下或多用户模式下来回切换时间,会导致不可预测的结果,所以, 如果当真要执行此类操作,请在单用户模式下进行. 80 Q: shell 文件中如何从文件中读参数? A: cat yourfile`

81 Q: 如何分析网络负载,在SUN上面有没有相应的工具 A: netstat -i

82 Q: 请问目前SUN E250,E450,E3500支持的CPU主频和缓存分别是多少?您能将这

些配置列表发给我吗?

A: docs.sun.com 有 硬件的answerbook ,可以参考一下。

现在支持的CPU到400M, 480M 产品已有.but still have not released

83 Q: mt -f /dev/rmt/0 有个参数:retension中文为\拉紧\,在磁带操作中具体 做什么?

A: the man page of this command said it clearly: Rewind the cartridge tape completely, then wind it forward to the end of the reel and back to beginning- of-tape to smooth out tape tension. so ,it is not 拉紧, but 放松 instead.

84 Q: 具体问题是:有一个进程不停的向该文件增加内容,同时另外一个进程建立了 与该文件的管道,从该文件中读取一行记录进行处理。然后删除该行记录。因 此需要保持该文件i-node不能改变,否则,向该文件写的进程就不能将信息写 入该文件了。有没有解决方法,请指教。 A: I don't know if I have understood you :

If you want save this file for later use, you should not remove its' content,if you don't need these content, you don't need this file as well, you can use pipe only, or other interprocess communication methods.

85 Q: 我用dos2unix转换一文件,却不成功,提示信息如下:(我用PC机通过rexec远 程登陆的)

$dos2unix filename1 filename2

could not open /dev/kbd to get keyboard type US keyboard assumed could not get keyboard tyep US keyboard assumed 请问此问题是怎麽回事?如何解决? A: 权限问题, 检查一下 /dev/kbd 读写权限

86 Q: 我希望在一台ultra机器为以下网络配置路由 子网:10.1.0.0 掩码:255.255.0.0 网关:10.220.10.113 应该如何配置?

用以下命令可以吗?如果永久配置需要修改那些文件? %route add 10.1.0.0 10.220.10.113 A: no,try this commond: #route add default 10.220.10.113

87 Q: 有个patch 107311-09,能解决CC4.2不能处理#pragma pack()的问题吗? A: the right patch is 104631, but you should add all related patch to avoid other problem,find them at: sunsolve.sun.com 88 Q: 在CSH下我输入以下命令? $setenv IWAVE 'pwd' $echo $IWAVE 结果显示为:pwd

在我的理解中应该是将pwd的输出(如/tmp)赋值给变量IWAVE,所以我想象的 输出是/tmp

A: use ` instead ' apparently,they are different. read some unix books for reference

89 Q: 为什么有时普通用户不能登录CDE?

A: 这个错误可能是由于CDE的不正确设置造成的。在每一个用户的home目录下有一 个.dt子目录.在此目录下有一个errorlog文件记录了CDE登录失败的原因.查 看此文件可以找到失败的原因.一个可行的方法是:使用root登录并且删除对 应用户home目录下的.dt目录,同时可以删除;/.dtprofile文件, 然后使用 用户口令登录即可.外检查/usr/dt/bin/dtsessoin的使用权限.正确的权限应 当是-r-sr-xr-x

90 Q: 关于Solaris8上DHCP的配置问题安装Solaris8后,进程dhcpagent的CPU占用率一

直都超过88%, 请问有什么方法可以解决.谢谢. A: I solve this program by going to the field sit.

The update period parameter can not be set longer than 2 weeks in the DHCP server side.

91 Q(1)能否在Ultra60上只安装64位的Solaris8? (2) Solaris8安装在Ultra60上,内核是32位还是64位? (3)在其上安装的Oracle 8是安装的32位版本还是64位版本?

A: Solaris8 的内核是64位的, 但是,它同时带有32位程序的解释器,也就是说32位 的程序也可以在Solaris8上面运行。事实上Solaris8上面有一些系统命令就是 32位的程序,如link等。所有的Solaris8都是64位的,但是都带有32位的解释 器。(就现在的情况而言,32位的解释器是必 须的)。在Solairs 8上面运行 的应用程序可以是64位,也可以是32位的,包括Oracle 8在内

92 Q: 很感谢你的答复。原来不能创建用户的原因应该是文件系统已满,我删除了一 些用户账号后,创建正常。现在的问题是c0d0t0s0文件系统的容量太小,现在 已经达到100%,如何扩展这个文件系统,是否只有重装系统这一个办法? A: 在系统安装时,各个分区划分的有些不太合理。/ 目录和 /usr 太小 /export/home和/tmp 太大。实际上在安装时,比较合理的办法是只设置 / 和 /tmp,/tmp最多 500M即可。然后在 / 上面建立/usr,/opt 和/export/home。 现在补救的办法是利用软link的办法:首先将一些在/或/usr中不太是系统直接 使用的目录(一定不可以包含/usr/sbin,/sbin, /etc,等等)转移到有空间的分 区上面,然后使用ln建立软连接。关于ln的使用可以man.这种办法是不得已而 为之。不是很好把握,搞不好就会死机,并且启动不起来。所以在进行此项活 动时,首先要备份数据,以免发生以上情况时丢失。如果您在下午下班的时间 可以抽出一点时间,最好还是将系统重新安装一遍的好。因为,每一个目录都 有一定的用意,一些软件的安装不是地方会让人感到很别扭。而使用软连接又 会降低系统的运行速度。

93 Q: 求助--请教一个多线程编程问题。关于我们发现的问题具体现象如下: 函数 void* A(void *pInput) {

char szBuf[30000]; //this buffer maybe larger than 30,000 ... ... }

在多线程程序中,该函数在main中运行(此时相当于在主线程中运行)正常。 如果使用pthread_create创建一个线程,以A作为线程入口函数,用内存测试工 具purify可以观察到该线程运行过程中出现Beyond Stack Read、Beyond Stack Write错误。如果把szBuf改为堆中分配的内存,则无此问题。据此,我们判断 是线程的栈空间溢出造成该问题。按资料描述,主线程的缺省栈空间大小为8M ,子线程缺省栈空间为2M;我们使用pthread_attr_setstack函数将子线程的栈 空间设置为8M,但仍未解决问题。后又将线程属 性设置为

PTHREAD_SCOPE_SYSTEM, 问题仍然存在。函数A以静态库方式由第三方提供, 我们现需要使之在一个子线程中运行,因此希望能够提供主线程与子线程差异 的资料,除堆栈空间、调度方式外,是否还有其他差别,造成以上错误的发生 A: In fact, there is no problem in the program. I think there is a bug in their debug tool: purify. You can use dbx to debug your program.

94 Q: 请问一块硬盘上可以有两个Solaris分区吗?在一块硬盘上分了两个solaris分 区,一个是active的系统安装分区,另一个是后来用fdisk创建的,请问怎样把 第二个分区加入到solaris系统中使用。谢谢。

A: Yes, There can be up to six partitions in a disk. you can see the partition using utility format. Command list: #format

Then you will see the disks installed in you system.then select the disks you are interested in. then print \to see the partition information. The partition you want to add to the system can be identified as c#t#d#s#. Make sure the mount point( a empty directory in file system). such as /disk1.then run the

6.mount /dev/dsk/c0t0d0s0 /tmp/root/xxx (在这里c0t0d0s0是你的root盘) 7.运行csh

8.setenv TERM vt220

9.cp /tmp/root/xxx/etc/shadow /tmp/root/xxx/shadow/shadow.bak 10.vi /tmp/root/xxx/shadow,并且将root项里的password域删除即可。 11.重启动,你就可以以无密码的root登陆了,登录后,更改root的密码。 111 Q: In solaris 2.6. when i use command \ CDE will be killed and the eviroment will change to CDE login. I looked up the man manual about \ can use the command\ solaris7 and solairs 8, with common id,i can't use the common.can you tell me why i can execute \A: Just see the access mode of /usr/sbin/killall. If you can use it with a common account identity, the access mode should be x-rsx-rx-r. If you can not use it in a common account identity, the mode should be x-r--r--r. You can change the mode as you like, whenever in 2.6, or 2.7 or 2.8.

112 Q: I downloaded the SDM2.3 from the Download Center of \ ,read the White Paper and web detailed describing.But it is only the outlook of the software. I need the detailed document about how to integrated my own network management application to Solstice. A: I transfer this messag to Sun Service in Guangdong.

113 Q: 请问有没有磁盘管理工具。我们有一台E450,有5块硬盘,想做RAID,但是没有工 具.

A: If the machine's OS is solaris 2.8, the storage management software is also installed in you machine. You can make the RAID by issuing the command family: /usr/sbin/meta*; If you are not so familiar with these commands. I can do it for you. or you can use solstice disksuite, it is a GUI tool.

114 Q: 怎样强制更改NIS客户端的本地NIS数据表?有时候NIS客户端和NIS服务器端有

时会出现不一致的情况.NIS服务器和NIS slave 服务器也会出现这种情况。 A: 你可以用yppush和 ypxfr 来做这种工作,更常见的方法是把它们写进cron,定 期更新,具体步骤请查阅Answerbook.

115 Q: 为了将工作站设为从DHCP动态分配IP,并且将主机名由\改为原名 修改了/etc/init.d/rootusr,将dhcpinfo后面三行(不是四行)注释掉; hostname=`/sbin/dhcpinfo Hostname` # case $? in

# 0) [ -z \# 2) try_dhcp=no ;; esac

重启后,提示:

/sbin/rcs:ysntax error at line 143 : 'esac' unexpected INIT:cannot creat /var/adm/utmp or /var/adm/utmpx INIT:SINGLE USER MODE

输入root口令后,只能运行在单用户模式,且vi、ls等都不能用(#vi:not found) 如何才能打开/etc/init.d/rootusr文件进行修改,恢复正常状态。

A: 请找一个SOLARIS的安装启动盘,使用以下方法可以修改rootusr文件,步骤如 下:

1.把你的solaris光盘放进cdrom 2.键入stop+a

3.当出现'ok'字样时,键入boot cdrom -s 4.cd /tmp

5.mkdir /tmp/xxx (xxx是什么东西无关紧要,随便取一个名字,如test) 6.mount /dev/dsk/c0t0d0s0 /tmp/xxx (在这里c0t0d0s0是你的root盘) 7.运行csh

8.setenv TERM vt220

9.vi /tmp/xxx/etc/init.d/rootusr,把esac那行也注释掉即可。 10.把solaris光盘拿出,reboot,重启动即可。

116 Q: 一台Ultra60工作站,其固定IP为10.11.105.247,用ifconfig hme0 dhcp start总是失败,如下所示。 # netstat -a|grep 4999 # ifconfig hme0 dhcp start

May 7 20:11:11 hwMusa01 dhcpagent[478]: ERROR! Address 10.11.105.147 is already in use ifconfig: internal error in DHCP agent # netstat -a|grep 4999

localhost.4999 *.* 0 0 0 0 LISTEN

localhost.4999 localhost.1023 32768 0 32768 0 TIME_WAIT

抓包发现是dhcp服务器offer的IP地址10.11.105.147被decline了。手工运行 dhcpagent,提示4999端口被使用了。以前此工作站曾配置为固定IP: 10.11.105.147,但现在已改为10.11.105.247并重启过多次。请问,可能是什 么原因导致dhcp失败??

A: 导致问题出现的原因是,由于客户机在申请原来的被保留分配的IP时,服务器 发现这个IP不能够被使用(已经有其它机器使用了这个IP地址)。使客户机申 请失败,并且使其中的某些进程不能正常退出,继续占用了端口4999而使后面 的申请不能进行。办法是找到占用端口4999的进程,杀掉即可。找到这个进程 的办法是,这个申请进程是带有dhcp字样的。 # ps -e | grep dhcp

会出现一到两个进程号。验证这些进程是否占用了4999是看进程打开的文件: # /usr/proc/bin/pfiles #pid

早到进程然后杀掉。这样就可以继续启动Client 端的dhcp申请。注意,修改 服务器的设置使新的申请可以成功。

117 Q: 我们有一台Natra T1,它的/tmp目录已经长到90%,如果目录满了是否会使系统 运行异常.(因为我们运行的业务不能停,故不能重启SUN机器来让系统清空该目 录,也不能直接清空该目录,应为应用程序正在运行.)下面是一些数据:

# df -k

Filesystem kbytes used avail capacity Mounted on /proc 0 0 0 0% /proc

/dev/dsk/c0t0d0s0 1258491 51942 1143625 5% / /dev/dsk/c0t0d0s6 1612343 500741 1063232 33% /usr fd 0 0 0 0% /dev/fd

/dev/dsk/c0t0d0s3 33099 9211 20579 31% /var

/dev/dsk/c0t0d0s7 13550703 838475 12576721 7% /export/home /dev/dsk/c0t0d0s5 30743 10319 17350 38% /opt

/dev/dsk/c0t0d0s1 548687 369368 124451 75% /usr/openwin swap 627864 563360 64504 90% /tmp # cd tmp # ls ps_data # ls -a -l total 98

drwxrwxrwt 6 sys sys 443 May 7 15:29 . drwxr-xr-x 22 root root 512 Mar 20 17:45 .. drwxrwxr-x 2 root root 176 Feb 27 23:18 .X11-pipe drwxrwxr-x 2 root root 176 Feb 27 23:18 .X11-unix drwxrwxrwx 2 root root 179 Feb 27 23:18 .pcmcia drwxrwxrwt 2 root root 327 Feb 27 23:18 .rpc_door -rw-rw-r-- 1 root sys 5056 Feb 27 23:18 ps_data # cd .pcmcia # ls -a -l total 32

drwxrwxrwx 2 root root 179 Feb 27 23:18 . drwxrwxrwt 6 sys sys 443 May 7 15:35 .. prw-rw-rw- 1 root root 0 Feb 27 23:18 pcram # cd .. # pwd

/tmp # cd .rpc_door # ls -a -l total 32

drwxrwxrwt 2 root root 327 Feb 27 23:18 . drwxrwxrwt 6 sys sys 443 May 7 15:36 ..

Drw-r--r-- 1 root root 0 Feb 27 23:18 .rpc_100029.1 Drw-r--r-- 1 root root 0 Feb 27 23:18 .rpc_100029.2 Drw-r--r-- 1 root root 0 Feb 27 23:18 .rpc_100029.3 # cd .. # cd .X11-pipe # ls -a -l total 32

drwxrwxr-x 2 root root 176 Feb 27 23:18 . drwxrwxrwt 6 sys sys 443 May 7 15:37 .. -rw-rw-rw- 1 root root 0 Feb 27 23:18 X0 # cd .. # ls ps_data # cd .X11-unix # ls -al total 32

drwxrwxr-x 2 root root 176 Feb 27 23:18 . drwxrwxrwt 6 sys sys 443 May 7 15:38 .. srwxrwxrwx 1 root root 0 Feb 27 23:18 X0 等待您的回答,谢谢

A: 我认为是系统统计信息错误的, 本人的经验是当/tmp的使用率超过10%时,系统就

变的很慢了。出现这种情况,首先,要检查系统中运行的程序有没有不停分配内存,

却没有释放(指自己开发的程序)。另外看一下系统对/tmp的swap交换情况。使用工 具sar 和iostat 都可以看到。关于sar和iostat的用法, 可以看man即可。 118 Q: 有一用MOTIF 写的程序,运行之后不能显示中文(乱码),由于显示的信息是 不固定的,故不能使用资源文件.怀疑程序中与创建字体时使用了以下的函数 有关,但注释掉后也一样:

font1=XLoadQueryFont(XtDisplay(toplevel), \font2=XLoadQueryFont(XtDisplay(toplevel), \font3=XLoadQueryFont(XtDisplay(toplevel), \fontlist=XmFontListCreate(font1, \fontlist=XmFontListAdd(fontlist, font2, \fontlist=XmFontListAdd(fontlist, font3, \

运行环境是ULTRA 60 ,Solaris 2.6 ,安装了中文环境。编译环境是SUN C++ 4.0 。 还怀疑与LANG 相关,曾试过设置为zh ,chinese 等也不行,请教此问题如何解决? A: 实际上,关于选择字体和字符集可以看;这个资料,使 用系统提供的标准工具来从中间找到系统中存在的字体和字体的名称。这个资料在 Answer Book 的System Administration Collection 中。 实际上,上面的问题不 出现在字体的选择上面, 而是在MOTIF中在选择框的使用设置中还要设置一次字体 119 Q: 请问SUN的E250以上机器支持\双机热备+磁盘阵列\的使用方式吗?Ultra系 列的机器是否也能支持呢?

A: SUN的E250以上机器支持\双机热备+磁盘阵列\的使用方式,可以使用 SunCluster软件实现;Netrat系列电信服务器也支持;Ultra系列的机器,不 在支持的列表中。但是,\双机热备+磁盘阵列\的具体含义应该搞清楚。推 荐的文档在sun cluster collection 中。

120 Q: 我在一个JAVA程序中打开50个SOCKET端口,结果出现异常: java.net.SocketException:Too many open files

请问如何解决此问题?谢谢!另外,请问在一个JAVA进程中可以同时启动的线 程数是多少?最大线程数受什么限制?能否达到240个线程?谢谢!如上问题 如果可以通过修改配置来解决的话,会有什么样的负面影响?

A: You have two ways to modify the limit number of files that a process can open simutanously.

One: modify the /etc/system file add the following entry: set rlim_fd_cur = #n

#n is the number you want. Should be no more than 1024. You should reboot the machine. Two: Use the system command: ulimit $ulimit -n #n

Note: You should use B-shell.

And using the same terminal session(in the same terminal window) to run the your application program( to guarantee your application process is a child process of the setting terminal.)You can man ulimit to see the detailed usaged. The disadvantage brought by incread the file limite for a process or the whole system is increasing the system memory usage. But, for today's machine, this disadvantage is not too expensive. (William said There is no limit for max open

socket number in Java. But the operating system has a limit for max open file descriptors.A socket resource is treated as a file descriptor in Unix. The previous email answered your question. You can try as said.

121 Q: 我想把一个HP平台上运行的B SHELL 脚本在SOLARIS 2。6上运行,但是出现了

问题:要运行的脚本部分: command_count = 0

command_item[$command_count]=check_AutoRaid command_count=`expr $command_count + 1`

command_item[$command_count] = check_system_resource command_count=`expr $command_count + 1` command_item[$command_count]= check_diskspace

command_count=`expr $command_count + 1` command_item[$command_count]= check_bill_record command_count=`expr $command_count + 1`

本文来源:https://www.bwwdw.com/article/fj68.html

Top