诡异的遭遇

将Oracle ERP产品环境克隆到一个新的测试环境,是Oracle ERP DBA的日常工作。
但是这次一个环境克隆到今天也没成功,遭遇了一波又一波的问题,只能用诡异来形容。

我们的产品环境服务器在各个省会城市,而测试环境服务器则全部在北京,所以平时的操作是晚上业务可以停顿的时候,关闭数据库,然后将所有数据文件和客户化程序tar到磁带上,第二天省里面将磁带用快递送到北京,然后我们开始克隆测试环境。

关闭数据库,往磁带中tar文件,完毕以后再重新启动环境,这些都是通过脚本和crontab自动完成的。同样的操作已经成功运行了无数次。

但是这次:
1。第一天拿到磁带,作数据库clone的时候,报错说undo01.dbf找不到,然后发现磁带中根本没有没有这个文件,也就是备份的时候就出了问题,这个文件没有tar成功。最后发现原因是,HP的tar最多只能支持单个文件8G,而那个undo01.dbf在这次备份前因为需要导入大量数据而扩大到了10G,所以tar失败。

2。此时是第二天白天,无法down库,只能等到晚上12点以后,开始用FTP直接从产品环境传输数据文件到测试环境。临晨4点登录系统发现FTP异常中止了,然后查看测试环境的文件系统,发现几乎100%空间占用,但是用du -sk却显示只使用了50G而已。
bdf的结果
/dev/hbvg01/lvhbdevdata 102432768 100529536 1888536 98% /heuat/data
du -sk 的结果
56461752 /heuat/data
反复检查,结果发现是删除原来测试环境中的数据文件时没有关闭Oracle的instance,导致磁盘空间没有释放。此时,不禁想,如果是Windows系统,那么instance打开的时候根本就不会允许删除数据文件,也就没这个问题了,所以,事务总有好和坏的两面。

3。kill掉后台oracle进程,重新FTP剩余的数据文件,到早上8点,成功传输完毕,开始clone,将近10点的时候,clone结束,正在作最后的打扫工作,忽然登录数据库报错,查看数据文件,竟然发现有一堆数据文件的属主发生了变化,当时脑袋已经比较混沌了,蒙了几分钟,然后ps后台的进程,结果发现有一个mv的进程,正在把其它位置的数据文件转移到我正在clone的这个环境中,立刻打电话给同事。。。他的误操作覆盖掉了我刚刚做完的新数据库,彻底崩溃,我一个晚上的工作啊,又白费了,这个环境仍旧宣告clone失败。两个字评语,诡异!我不由又有些怀念Windows了。

然后就是一通疯狂的电话联系,跟这个人说明情况,跟那个人商量解决方法,一直搞到中午11点多,洗澡,睡觉。

如何将UNIX Shell作为Concurrent Program来运行

通常在Oracle ERP系统中需要有数据导入的工作,比如各个模块的期初数据。这些数据导入的工作都是由客户方的人员在Oracle ERP系统中运行特定的Concurrent Program来执行的,也就是操作人员点几下鼠标,提交一个请求的事情。

那么如何实现数据导入功能变为Concurrent Program呢?

1。将数据导入功能写成一个UNIX Shell,允许接受参数,在其中调用sql loader,这个脚本如何写不是本文的内容

2。比如这个数据导入是总帐模块需要用的,那么通常我们就把这个Shell脚本放在$CGL_TOP/bin目录下,假设脚本的名字的为hostprog.prog,扩展名为prog这是必须的。

3。在相同目录下生成link,注意此处生成的link名称为去掉了prog扩展名的文件名,这同样是必须的。
link -s $FND_TOP/bin/fndcpesr $CGL_TOP/bin/hostprog

4。在ERP系统中注册Concurrent Program Executable,注意选择Type为host

5。在ERP系统中注册Concurrent Program Define,此时可以设置Shell脚本需要接受的外部参数的默认值。注意,当请求调用脚本的时候,会往脚本中传输4个参数值,依次是 orauser/pwd, userid, username, request_id,分别表示数据库用户/密码,ERP用户ID,ERP用户名,当前请求编号,这是我们在写脚本时可以使用的$1-$4这4个参数,而额外自定义的参数一定要从$5开始。

6。找到需要执行这个脚本的ERP用户所拥有的职责,然后将该Program加入职责的请求组中。

7。切换到相应职责,提交请求。

可以参看Metalink上的文章:Note:147455.1
Running a Shell Script as a Concurrent Program

如何给OracleERP报表添加Excel查看方式

pic1

如何实现如上图在查看Oracle ERP报表时可以选择Microsoft Excel类型?很简单,作下面的设置就可以了。

用sysadmin登录Oracle ERP系统,选择Install -> Viewer Options,然后添加一条新记录。新纪录的File Format为”Text”,Mime Type为”application/vnd.ms-excel”,Description为”Microsoft Excel”,保存。

pic2

记在这里,作个备忘。

再发招聘-电讯盈科(PCCW)

中国移动和中国网通的全国ERP项目,超大,需要招聘下列Oracle ERP相关人员,有兴趣的给我邮件。

职位1: (Senior) ERP Functional Consultant

工作范围

参与 ERP 项目实施,于重点省市进行模板设计、现状调研及业务流程重组等。

• 协助项目经理设计系统的整合方案;
• 为客户进行作业分析,清楚了解有关业务流程及客户需要;
• 与客户进行紧密的沟通及与项目技术人员协调,以提供最佳的 ERP 实施方案予客户, 包括提供实施策略建议等;
• 撰寫模版文件与培训资料。

职位要求

• 计算机或财务会计相关专业本科毕业及具有 4 年相关经验;
• 具有 3 – 4 年 Oracle ERP 经验;
• 熟悉 Oracle AP, AR, GL, FA, PA, CE, PO 或 INV 等模块;
• 熟悉电信企业的基本物流或财务流程;
• 具有注册会计师专业优先;
• 具领导才能、良好的沟通技巧及积极的团队精神;
• 有强烈的进取精神,能够在压力下工作;
• 良好的英语阅读能力;
• 能经常在国内出差;
• 北京或广州base。

职位2: (Senior) ERP Technical Consultant

工作范围

参与 ERP 项目的技术设计,于重点省市进行模板设计、现状调研及业务流程重组等。

• 协助项目经理设计系统的整合方案;
• 负责 ERP 的设计与建立工作,包括功能客户化、开发通用报表模板、规范报表格式
与内容、程序移植和测试等;
• 与客户进行紧密的沟通及与项目实施人员协调,以提供最佳的ERP技术方案予客户;
• 处理系统开发及相关的技术问题。

职位要求

• 计算机或相关专业本科毕业及具有 3 年相关经验;
• 具有 3 – 4 年Oracle Developer 2000 或 Developer 6i (表格及报表)、PL/SQL、UNIX、JAVA、J2EE 实际工作经验;
• 有Oracle ERP Development 的工作经验优先;
• 具领导才能、良好的沟通技巧及积极的团队精神;
• 有强烈的进取精神,能够在压力下工作;
• 良好的英语阅读能力;
• 能经常在国内出差;
• 北京或广州base。

职位: Oracle ERP 技术专员 (DBA)

工作范围

参与 Oracle ERP 项目的技术设计,驻北京总部利用网络对各省市Oracle ERP 系统进行数据库技术方面的指导和支持。

• 从事ERP项目中应用系统技术方面的工作;
• 为客户化工作, 从数据库及其工具方面建议使用最新、最好的技术;
• 协助解决客户化工作中遇到的数据库方面的难点和问题;
• 协助项目经理设计系统的整合方案;
• 系统安装、维护、技术及安全方面给予建议、指导和支持;
• 定期检查客户在系统维护方面的工作情况;
• 与客户进行紧密的沟通及与项目实施人员协调,以提供最佳的ERP技术方案予客户;
• 为其他工作组提供一个良好的工作运行环境,完成项目经理分派的任务。

职位要求

• 计算机或相关专业本科毕业及具有起码 2 年相关经验;
• 具有 2-3 年数据库、网络及应用软件、Oracle Developer 2000 或 Developer 6i (表格及报表)、PL/SQL、UNIX 实际工作经验;
• 精通 DBA 工作包括备份及恢复、系统安装及优化等;
• 有Oracle ERP DBA 的工作经验和Oracle OCP证书优先;
• 具领导才能、良好的沟通技巧及积极的团队精神;
• 有强烈的进取精神,能够在压力下工作;
• 良好的英语阅读能力;
• 在北京工作者优先考虑。