免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2599 | 回复: 0
打印 上一主题 下一主题

AS400性能维护 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-03-22 13:44 |只看该作者 |倒序浏览
AS400性能的调优,其实是个很系统化的工作,需要从两个大方面考虑:

一 系统级:硬盘、内存、线程、作业、错误信号、耗资源进程、IFS碎片重组;
二 数据库:死锁、表碎片重组、临时空间释放;

针对每个方面,具体应用:

1 看系统使用状况:WRKSYSSTS , wrkdsksts
(Work with System Status)
-->检示系统资源 RAM 目前的使用状态.可动态调整资源的分配以取得系统运行最佳化.

2 线程数与作业数的修改:
一般用户很容易利用内存池的MAXACT参数来错误地控制作业数,而实际上此处的MAXACT所指的最大活动数应该是线程,没有意识到作业、线程的区别,导致该值设置较小,系统可能产生下列现象:
1)、Java 应用程序莫名其妙失败,当MAXACT的值很小,甚至为1时,Java程序就无法运行,且系统极有可能没有相关的出错提示信息。
2)、系统非常慢,但同时CPU利用率有很低,大量作业处于“Ineligible"状态。用户可以用WRKSYSSTS,就可能发现Act->Inel值不是零。
a、确保每个内存池的MAXACT的值足够大,如果同时用户利用MAXJOBS来控制子系统的活动作业数时,可以将内存池的MAXACT设为*NOMAX。
用CHGSHRPOOL来修改内存池的活动线程数:
CHGSHRPOOL ACTLVL(newmax)
b、用子系统参数 MAXJOB 控制子系统中同时活动的作业数:
CHGSBSD QBATCH MAXJOBS(newmax)
c、用子系统中的作业队列(JOBQ)定义进一步控制,从这作业队列中能同时进入该子系统中运行的作业数:
CHGJOBQE SBSD(QBATCH) JOBQ(QBATCH) MAXACT(新的最大作业数)

3 查看错误消息:DSPMSG QSYSOPR
-->检视系统是否有不正常讯息或响应讯息
WRKMSGQ (*QSYSOPR)
-->实例:WRKMSGQ QSYSOPR

4 杀死进程:wrkactjob 找QUSRWRK 后面的 subsystem ZDASOINIT
步骤:
1、查看进程所属ip,敲击5,再进入10
2、杀除进程 敲入4,再进入F4,修改为immed,或者用户自动退出

5 检验死锁:WRKOBJLCK ->F4(输入提示)
->命令:WRKOBJLCK OBJ(NISSAY/T_DEPT) OBJTYPE(*FILE)
(Work with Object Lock)
-->检示对象有无被其它作业使用或对象被何作业锁住, 将之排除

方法二:
1. On the IBM OS/400 command line, type the fo
AS400性能的调优,其实是个很系统化的工作,需要从两个大方面考虑:

一 系统级:硬盘、内存、线程、作业、错误信号、耗资源进程、IFS碎片重组;
二 数据库:死锁、表碎片重组、临时空间释放;

针对每个方面,具体应用:

1 看系统使用状况:WRKSYSSTS , wrkdsksts
(Work with System Status)
-->检示系统资源 RAM 目前的使用状态.可动态调整资源的分配以取得系统运行最佳化.

2 线程数与作业数的修改:
一般用户很容易利用内存池的MAXACT参数来错误地控制作业数,而实际上此处的MAXACT所指的最大活动数应该是线程,没有意识到作业、线程的区别,导致该值设置较小,系统可能产生下列现象:
1)、Java 应用程序莫名其妙失败,当MAXACT的值很小,甚至为1时,Java程序就无法运行,且系统极有可能没有相关的出错提示信息。
2)、系统非常慢,但同时CPU利用率有很低,大量作业处于“Ineligible"状态。用户可以用WRKSYSSTS,就可能发现Act->Inel值不是零。
a、确保每个内存池的MAXACT的值足够大,如果同时用户利用MAXJOBS来控制子系统的活动作业数时,可以将内存池的MAXACT设为*NOMAX。
用CHGSHRPOOL来修改内存池的活动线程数:
CHGSHRPOOL ACTLVL(newmax)
b、用子系统参数 MAXJOB 控制子系统中同时活动的作业数:
CHGSBSD QBATCH MAXJOBS(newmax)
c、用子系统中的作业队列(JOBQ)定义进一步控制,从这作业队列中能同时进入该子系统中运行的作业数:
CHGJOBQE SBSD(QBATCH) JOBQ(QBATCH) MAXACT(新的最大作业数)

3 查看错误消息:DSPMSG QSYSOPR
-->检视系统是否有不正常讯息或响应讯息
WRKMSGQ (*QSYSOPR)
-->实例:WRKMSGQ QSYSOPR

4 杀死进程:wrkactjob 找QUSRWRK 后面的 subsystem ZDASOINIT
步骤:
1、查看进程所属ip,敲击5,再进入10
2、杀除进程 敲入4,再进入F4,修改为immed,或者用户自动退出

5 检验死锁:WRKOBJLCK ->F4(输入提示)
->命令:WRKOBJLCK OBJ(NISSAY/T_DEPT) OBJTYPE(*FILE)
(Work with Object Lock)
-->检示对象有无被其它作业使用或对象被何作业锁住, 将之排除

方法二:
1. On the IBM OS/400 command line, type the following:CHGPF FILE(xxxxx/yyyyy)
2. Press the F10 key and Page Down.
3. Is the Maximum File Wait Time set to *IMMED? If so, on the OS/400 command line,
type the following:
CHGPF FILE(MGTEST/T_DEPT) WAITFILE(*CLS)

6 重组数据库表:/* 重组表 */
CL:RGZPFM FILE(MGTEST/T_COV00002) MBR(*FIRST) KEYFILE(*NONE);

7 IFS重组:
RGZDLO DLO(*)

8 初始程序装载(Initial Program Loading,简称IPL)在进行过程中,会释放诸如占用的临时空间等部分系统资源,所以定期做IPL也是优化空间使用的一种手段。
llowing:CHGPF FILE(xxxxx/yyyyy)
2. Press the F10 key and Page Down.
3. Is the Maximum File Wait Time set to *IMMED? If so, on the OS/400 command line,
type the following:
CHGPF FILE(MGTEST/T_DEPT) WAITFILE(*CLS)

6 重组数据库表:/* 重组表 */
CL:RGZPFM FILE(MGTEST/T_COV00002) MBR(*FIRST) KEYFILE(*NONE);

7 IFS重组:
RGZDLO DLO(*)

8 初始程序装载(Initial Program Loading,简称IPL)在进行过程中,会释放诸如占用的临时空间等部分系统资源,所以定期做IPL也是优化空间使用的一种手段。

=================================================================================

java的30个目标(转载)(2006-11-29 09:53:30)   分类:编程

你需要精通面向对象分析与设计(OOA/OOD)、涉及模式(GOF,J2EEDP)以及综合模式。你
应该十分了解UML,尤其是class,object,interaction以及statediagrams.

你需要学习JAVA语言的基础知识以及它的核心类库(collections,serialization,stream
s,networking,multithreading,reflection,event,handling,NIO,localization,以及其他
)。

你应该了解JVM,classloaders,classreflect,以及垃圾回收的基本工作机制等。你应该有
能力反编译一个类文件并且明白一些基本的汇编指令。

如果你将要写客户端程序,你需要学习WEB的小应用程序(applet),必需掌握GUI设计的
思想和方法,以及桌面程序的SWING,AWT,SWT。你还应该对UI部件的JAVABEAN组件模式有
所了解。JAVABEANS也被应用在JSP中以把业务逻辑从表现层中分离出来。

你需要学习java数据库技术,如JDBCAPI并且会使用至少一种persistence/ORM构架,例如
Hibernate,JDO,CocoBase,TopLink,InsideLiberator(国产JDO红工厂软件)或者iBatis。
你还应该了解对象关系的阻抗失配的含义,以及它是如何影响业务对象的与关系型数据库
的交互,和它的运行结果,还需要掌握不同的数据库产品运用,比如racle,mysql,mssql
server.

你需要学习JAVA的沙盒安全模式(classloaders,bytecodeverification,managers,polic
yandpermissions,
codesigning,digitalsignatures,cryptography,certification,Kerberos,以及其他)

还有不同的安全/认证API,例如JAAS(JavaAuthenticationandAuthorizationService),

JCE(JavaCryptographyExtension),JSSE(JavaSecureSocketExtension),以及JGSS(JavaGe
neralSecurityService).

你需要学习Servlets,JSP,以及JSTL(StandardTagLibraries)和可以选择的第三方TagLi
braries。

你需要熟悉主流的网页框架,例如JSF,Struts,Tapestry,Cocoon,WebWork,以及他们下面的
涉及模式,如MVC/MODEL2.

你需要学习如何使用及管理WEB服务器,例如tomcat,resin,Jrun,并且知道如何在其基础
上扩展和维护WEB程序。

你需要学习分布式对象以及远程API,例如RMI和RMI/IIOP。

你需要掌握各种流行中间件技术标准和与java结合实现,比如Tuxedo、CROBA,当然也包括
javaEE本身.

你需要学习最少一种的XMLAPI,例如JAXP(JavaAPIforXMLProcessing),JDOM(JavaforXMLD
ocumentObjectModel),DOM4J,或JAXR(JavaAPIforXMLRegistries).

你应该学习如何利用JAVAAPI和工具来构建WebService。例如JAX-RPC(JavaAPIforXML/RPC
),SAAJ(SOAPwithAttachmentsAPIforJava),JAXB(JavaArchitectureforXMLBinding),JAXM
(JavaAPIforXMLMessaging),JAXR(JavaAPIforXMLRegistries),或者JWSDP(JavaWebServic
esDeveloperPack)。

你需要学习一门轻量级应用程序框架,例如Spring,PicoContainer,Avalon,以及它们的Io
C/DI风格(setter,constructor,interfaceinjection)。

你需要熟悉不同的J2EE技术,例如JNDI(JavaNamingandDirectoryInterface),JMS(JavaMe
ssageService),JTA/JTS(JavaTransactionAPI/JavaTransactionService),JMX(JavaManag
ementeXtensions),以及JavaMail.

你需要学习企业级JavaBeans(EJB)以及它们的不同组件模式:Stateless/StatefulSess
ionBeans,EntityBeans(包含Bean-ManagedPersistence[BMP]或者Container-ManagedPers
istence[CMP]和它的EJB-QL),或者Message-DrivenBeans(MDB).

你需要学习如何管理与配置一个J2EE应用程序服务器,如WebLogic,JBoss等,并且利用它
的附加服务,例如簇类,连接池以及分布式处理支援。你还需要了解如何在它上面封装和配
置应用程序并且能够监控、调整它的性能。

你需要熟悉面向方面的程序设计以及面向属性的程序设计(这两个都被很容易混淆的缩写
为AOP),以及他们的主流JAVA规格和执行。例如AspectJ和AspectWerkz。

你需要熟悉对不同有用的API和framework等来为你服务。例如Log4J(logging/tracing)
,Quartz(scheduling),JGroups(networkgroupcommunication),JCache(distributedcachi
ng),Lucene(full-textsearch),JakartaCommons等等。

如果你将要对接或者正和旧的系统或者本地平台,你需要学习JNI(JavaNativeInterface)
andJCA(JavaConnectorArchitecture).

你需要熟悉JINI技术以及与它相关的分布式系统,比如掌握CROBA。

你需要JavaCommunityProcess(JCP)以及他的不同JavaSpecificationRequests(JSRs),例如
Portlets(16,JOLAP(69),DataMiningAPI(73),等等。

你应该熟练掌握一种JAVAIDE例如sunOne,netBeans,IntelliJIDEA或者Eclipse。(有些人
更喜欢VI或EMACS来编写文件。随便你用什么了:))

JAVA(精确的说是有些配置)是冗长的,它需要很多的人工代码(例如EJB),所以你需要
熟悉代码生成工具,例如XDoclet。

你需要熟悉一种单元测试体系(JNunit),并且学习不同的生成、部署工具(Ant,Maven)


你需要熟悉一些在JAVA开发中经常用到的软件工程过程。例如RUP(RationalUnifiedProce
ss)andAgilemethodologies.

你需要能够深入了解加熟练操作和配置不同的操作系统,比如GNU/linux,sunsolaris,macO
S等,做为跨平台软件的开发者。

你还需要紧跟java发展的步伐,比如现在可以深入的学习javaME,以及各种java新规范,技
术的运用,如新起的web富客户端技术。

你必需要对opensource有所了解,因为至少java的很多技术直接是靠开源来驱动发展的,如
java3D技术。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP