• 全部
  • 经验案例
  • 典型配置
  • 技术公告
  • FAQ
  • 漏洞说明
  • 全部
  • 全部
  • 大数据引擎
  • 知了引擎
产品线
搜索
取消
案例类型
发布者
是否解决
是否官方
时间
搜索引擎
匹配模式
高级搜索

solaris系统补丁介绍

2007-03-31 发表
  • 0关注
  • 0收藏 555浏览
粉丝: 关注:

1.补丁的种类及文件名

    solaris的补丁分为两类,一类是Point补丁,另一类是Cluster补丁。

a)Point补丁程序:

      这类补丁仅仅是针对某一问题或缺陷而发布的单个补丁程序,solaris7、solaris8、solairs9的Patch一般为*.zip文件solaris2.6一般为.tar.Z或.tar.gz文件,它有如下编号方式:

patch base code-revision num  (如110668-04)

前面部分是这个补丁的主版本号(base code),后面部分是此补丁的修订号。两者合起来构成此补丁的Patch-ID。如上例编号为110668-04的补丁,110668为主版本号,04是修订号。此补丁是在110668-03的基础上做了新的修复。有一点需要指出,补丁版本号为110668的一系列补丁都是针对 /usr/sbin/in.telnetd 这一文件的不同问题的修复,110668-04发布以后,sun将不再提供110668-04以前的补丁,如110668-03等。

b) Cluster补丁程序: 

    cluster补丁仅仅是一系列point补丁的重新包装,并带有自动安装程序。Cluster补丁的命名方式如下:

version_Recommended

如:9_x86_Recommended.zip是针对Solaris 9 for X86的补丁集。

    8_Recommended.zip是针对Solaris 8 for Sparc 的补丁集。

    每个Cluster补丁都对应一个CLUSTER_README文件,详细描述了该Cluster包含的补丁,以及安装的方法或注意事项。

2.关于补丁的其他信息

    sun公司对每一版本的solaris都维护了一份Patch Reports,该Patch Reports包含了对应版本solaris所有补丁的描述。Patch Reports每月更新两次,可以从如下地址得到:

***.***/pub-cgi/show.pl?target=patches/patch-access&nav=patchpage

    另外sun还维护了一份Sun Alert Patch Report,该文档按产品分类,并且随时更新。从这里可以找到所有sun产品的更新文档及相应补丁,当然也包括的solaris的Sun Alert 文档、Patch ID、简要说明等。Sun Alert Patch Report从这里可以得到:

***.***/pub-cgi/show.pl?target=sunalert_patches

相应的solaris部分可从如下链接得到:

***.***/pub-cgi/show.pl?target=sunalert_patches#Solaris

表格按时间排序,从Category表格中可以知道此问题属于安全缺陷修复还是应用优化。

二、补丁的下载

    Cluster补丁可以从如下网址下载:

***.***/pub-cgi/show.pl?target=patches/patch-access&nav=patchpage

同样可以使用FTP协议下载,在***.***的/pacthroot/clusters可以找到所有的Cluster补丁。下载后为一个*_Recommended.zip文件。该压缩文件包含一份CLUSTER_README文件,建议安装前阅读此文件。

    Point补丁由于其分散性不易下载与管理,可以使用Sun Alert Patch Report或Patch Reports来查看补丁情况,这两份文档相应的Patch ID及对应下载地址。另外sun网站提供的Patch Finder 功能也可以使我们在知道Patch ID的情况下很方便的找到该补丁,连接如下:

***.***/pub-cgi/show.pl?target=patches/patch-access&nav=patchpage

同样,利用ftp协议从***.***的/patchroot/all_unsigned目录下也可以下载指定Patch。

    Sun公司建议所有下载的补丁都放到/var/tmp目录下(这也是通常的做法),如此将不会导致补丁安装时出现的任何permission/ownership的问题。

三、solaris补丁的安装和删除

3.1 /var/sadm/patch目录

    在/var/sadm/patch目录下,记录了已安装的补丁。

    如: # ls /var/sadm/patch 

    107558-05 107594-04 107630-01 107663-01 107683-01 

    107696-01 107817-01 107582-01 107612-06 107640-03

    建议不要对此目录做任何修改,此目录被破坏后将不能安装或删除任何补丁。

3.2 管理solaris补丁

    Solaris提供了两个命令来管理补丁,patchadd和patchrm。这两个命令是在Solaris 2.6版本开始提供的,在2.6以前的版本中,每个补丁包中都提供了一个installpatch 程序和一个backoutpatch 程序来完成补丁的安装和卸载。

    patchadd用来安装解压缩后的补丁程序。patchadd通过调用pkgadd 命令来安装补丁。安装补丁前,我们需要将补丁解压到/var/tmp下安装。安装补丁如下命令:

    # cd /var/tmp

    # patchadd 110668-04

    Checking installed patches...

    Verifying sufficient filesystem capacity (dry run method)

    Installing patch packages...     

    如果当前目录下有110668-04目录,patchadd将安装此补丁。补丁安装后,系统会备份原文件,以便在以后删除此补丁。如果使用patchadd -d 选项安装补丁,系统将不备份源文件,这意味着你将不能在以后删除此补丁。使用patchadd -p 选项可以检验已安装的patch,例如:

    # patchadd -p

    Patch: 106793-01 Obsoletes: Requires: Incompatibles:

    Packages: SUNWhea 

    . . .

    同样,solaris提供了另一命令来查看已安装的patch:

    # showrev -p

    Patch: 106793-01 Obsoletes: Requires: Incompatibles:

    Packages: SUNWhea

    . . .

    patchrm 如果因为某种情况你想卸载某一补丁,你可以使用patchrm命令来完成。此命令通过调用 pkgadd来恢复安装补丁前的文件备份来卸载补丁。使用Patch-ID作为patchrm的参数就可以卸载补丁:

    # patchrm 106793-01

    Checking installed packages and patches...

    Backing out patch 106793-01...

    Patch 106793-01 has been backed out.

    这里需要说明一下,在如下三种情况下,补丁将不能卸载:

    1).在安装patch时,用patchadd -d命令指定patchadd不备份被更新的文件。这样安装的patch无法删除。

    2).另一patch需要此patch,即存在dependence(关联性), 如一定要删掉该patch,先删掉另一patch。

    3).要删的patch已被另一更新的patch废弃了。如安装110668-04补丁后,如果以前安装过110668-03,则110668-03将被110668-04废弃,110668-03将无法删除。

3. Cluster补丁的安装

    Cluster补丁为单个补丁的集合,下载解压后,可以通过执行./install_Cluster脚本来完成补丁集的安装。执行./install_Cluster后,脚本将检查当前目录下的patch_order文件,此文件标明了Patch的安装顺序,./install_Cluster将按照patch_order文件给出的顺序来安装patch。如果没有patch_order文件,则假定当前目录下所有以1开始的目录名均为需要安装的补丁目录,并且假定这些目录的名称次序作为安装Patch的次序。因此你可以通过修改patch_order文件来决定安装或不安装某Patch。

 

4. 安装Patch时的注意事项

    由于在安装Patch时需要更新文件,故此Solaris官方推荐在安装补丁时进入单用户模式安装。在某些重要服务器上可能带来不便,因此你完全可以在多用户模式下通过停止相关服务进程来完成Patch的安装。

    Sun推出的Patch并不是每个都一定要安装的,因此需要在安装patch前仔细阅读README来确定是否需要安装此补丁。另外,某些补丁具有依赖性,需要先安装另一补丁才能完成此补丁的安装,这些都会在README中标明。总之,安装补丁之前强烈建议你阅读相应的README(每个Patch都提供单独的README文件)。

5. 安装PATCH过程中出现的问题

    在安装补丁的过程中,经常出现一些错误提示。例如:

    Installation of 123456-11 failed. Return code 2

    通过Return code我们可以知道错误类型。需要注意的是,Return code 2说明此补丁已被安装,Return code 8说明此补丁要修复的软件没有被系统安装。因此,2和8是完全可以被忽略的错误提示。下表说明了各个Return code对应的错误类型。

Exit code Meaning 

0 No error 

1 Usage error 

2 Attempt to apply a patch that's already been applied 

3 Effective UID is not root 

4 Attempt to save original files failed 

5 pkgadd failed 

6 Patch is obsoleted 

7 Invalid package directory 

8 Attempting to patch a package that is not installed 

9 Cannot access /usr/sbin/pkgadd (client problem) 

10 Package validation errors 

11 Error adding patch to root template 

12 Patch script terminated due to signal 

13 Symbolic link included in patch 

14 NOT USED 

15 The prepatch script had a return code other than 0. 

16 The postpatch script had a return code other than 0. 

17 Mismatch of the -d option between a previous patch install and the current one. 

18 Not enough space in the file systems that are targets of the patch. 

19 $SOFTINFO/INST_RELEASE file not found 

20 A direct instance patch was required but not found 

21 The required patches have not been installed on the manager 

22 A progressive instance patch was required but not found < tr>; 

23 A restricted patch is already applied to the package 

24 An incompatible patch is applied 

25 A required patch is not applied 

26 The user specified backout data can't be found 

27 The relative directory supplied can't be found 

28 A pkginfo file is corrupt or missing 

29 Bad patch ID format 

30 Dryrun failure(s) 

31 Path given for -C option is invalid 

32 Must be running Solaris 2.6 or greater 

33 Bad formatted patch file or patch file not found 

34 The appropriate kernel jumbo patch needs to be installed

35 Later revision already installed

If you run into the following errors, don't care about them. Reboot your system and check with uname -a.  The Generic_XXXXX-XX is the number of newest patch on your system.

Patch XXXXX-XX failed to install due to a failure produced by pkgadd.

See /var/sadm/patch/XXXXX-XX/log for details

Patchadd is terminating.

# more /var/sadm/patch/117350-24/log

Package not patched:

PKG=FJSVhea

Original package not installed.

Package not patched:

PKG=SUNWcar.d

Original package not installed.

Package not patched:

PKG=SUNWcar.m

Original package not installed.

Package not patched:

PKG=SUNWcar.us

Original package not installed.

Package not patched:

PKG=SUNWcarx.us

Original package not installed.

若您有关于案例的建议,请反馈:

作者在2007-10-15对此案例进行了修订
0 个评论

该案例暂时没有网友评论

编辑评论

举报

×

侵犯我的权益 >
对根叔知了社区有害的内容 >
辱骂、歧视、挑衅等(不友善)

侵犯我的权益

×

泄露了我的隐私 >
侵犯了我企业的权益 >
抄袭了我的内容 >
诽谤我 >
辱骂、歧视、挑衅等(不友善)
骚扰我

泄露了我的隐私

×

您好,当您发现根叔知了上有泄漏您隐私的内容时,您可以向根叔知了进行举报。 请您把以下内容通过邮件发送到pub.zhiliao@h3c.com 邮箱,我们会尽快处理。
  • 1. 您认为哪些内容泄露了您的隐私?(请在邮件中列出您举报的内容、链接地址,并给出简短的说明)
  • 2. 您是谁?(身份证明材料,可以是身份证或护照等证件)

侵犯了我企业的权益

×

您好,当您发现根叔知了上有关于您企业的造谣与诽谤、商业侵权等内容时,您可以向根叔知了进行举报。 请您把以下内容通过邮件发送到 pub.zhiliao@h3c.com 邮箱,我们会在审核后尽快给您答复。
  • 1. 您举报的内容是什么?(请在邮件中列出您举报的内容和链接地址)
  • 2. 您是谁?(身份证明材料,可以是身份证或护照等证件)
  • 3. 是哪家企业?(营业执照,单位登记证明等证件)
  • 4. 您与该企业的关系是?(您是企业法人或被授权人,需提供企业委托授权书)
我们认为知名企业应该坦然接受公众讨论,对于答案中不准确的部分,我们欢迎您以正式或非正式身份在根叔知了上进行澄清。

抄袭了我的内容

×

原文链接或出处

诽谤我

×

您好,当您发现根叔知了上有诽谤您的内容时,您可以向根叔知了进行举报。 请您把以下内容通过邮件发送到pub.zhiliao@h3c.com 邮箱,我们会尽快处理。
  • 1. 您举报的内容以及侵犯了您什么权益?(请在邮件中列出您举报的内容、链接地址,并给出简短的说明)
  • 2. 您是谁?(身份证明材料,可以是身份证或护照等证件)
我们认为知名企业应该坦然接受公众讨论,对于答案中不准确的部分,我们欢迎您以正式或非正式身份在根叔知了上进行澄清。

对根叔知了社区有害的内容

×

垃圾广告信息
色情、暴力、血腥等违反法律法规的内容
政治敏感
不规范转载 >
辱骂、歧视、挑衅等(不友善)
骚扰我
诱导投票

不规范转载

×

举报说明

提出建议

    +

亲~登录后才可以操作哦!

确定

亲~检测到您登陆的账号未在http://hclhub.h3c.com进行注册

注册后可访问此模块

跳转hclhub

你的邮箱还未认证,请认证邮箱或绑定手机后进行当前操作