Views given in this blog are my own and do not necessarily reflects views of my company
Thursday, 1 November 2012
Siebel: Object manager paramater configuration
The Siebel Object Manager is a multithreaded process, which means that one running process can execute multiple, concurrent threads. When an Object Manager is started on a Siebel server, an OM task will automatically be started (with status 'Handling Requests'). When users start to log in, each user login will spawn a new task. These user tasks will remain active until the user logs out. All these tasks will be counted towards the value of the MaxTasks parameter.
Multiple OM processes can be run on each Siebel Server. This multiprocessing and multithreaded programming model provides Siebel software with a very high degree of scalability, as users are constrained only by application server resources in the numbers of processes and threads that can be run to support very high numbers of concurrent users.
Processes and threads are programming terms for things running at the operating system level. At the Siebel Server level, more user-friendly terms are used to express the same concepts. The term Multithreaded Server, or MT Server, refers to an OM process, and the term Server Task refers to a user session being executed by a thread of that process.
As with any high performance system, proper tuning is required to assure optimal operation. The goal is to tune the SOM to efficiently use the database connections, memory, and CPU time while not succumbing to high levels of context switching. There are many parameters to consider when tuning a Siebel OM. Siebel Expert Services provides a Production Readiness review, to make sure that the Siebel application has been tuned correctly. The following case study will provide concepts and examples to educate the Siebel Administrator in tuning their Siebel eBusiness Application.
The first step to consider is the projected number of concurrent users for the Siebel application. In this case study, there are 1000 concurrent users, assuming an average think time of 30 seconds between user operations. The think time is the idle time when the server or the client is not doing anything; it does not include query time. During the think time, the user may be conversing on the telephone, working in another application (such as email) or doing some other task. Using the Server Manager command line utility, srvrmgr, the Siebel Administrator can run the "list statistics" command to calculate the "Average Think Time" for a process. This information is used to calculate the first set of parameters.
MaxTasks = concurrent users + anonymous user pool [1000+100]
MaxMTServers = MaxTasks / 100 [1100/100 = 11]
Number of Sessions per SISNAPI Connection = 20
Observations:
For environments where there is lack of machine resource, such as lack of memory, it is recommended a lower MaxTasks / MaxMTServer ratio. It is necessary to make tests to tune it and find a proper value. But the ratio in these scenarios can go from around 25 to 75.
For Object Managers that use Product Configurator, the recommended MaxTasks / MaxMTServer ratio is 25. The same 25 ratio is recommended for eCommunications Object Manager.
Max Tasks
Maximum number of tasks represents the maximum number of concurrent user sessions that can run on a server at one time. An MT Server is equivalent to a single process of an Object Manager. Each MT Server is implemented as an operating system process; it has its own memory space and processor identifier (PID). The default value is 20.
NOTE: For Siebel Servers running on the Solaris platform: When using the Oracle 8i client, setting a high ratio of tasks per OM process may cause the object manager to end unexpectedly. For additional information and workarounds for this behavior, review "Alert 881: Intermittent "Login Failed" Error Running Siebel Server on Solaris with Oracle 8i Database"
Note: There are limits on per process memory utilization set up at Siebel level & OS level.
If you have high number of tasks per process then this might cause problem.
Max MT Servers and Min MT Servers
Maximum MT Servers is the maximum number of MT Servers that can be run for this component on this server. It is also used to calculate how many tasks can be run on each MT Server. Minimum MT Servers determines how many MT Servers start initially when the Siebel Server starts. It also determines the minimum number of MT Servers to run on a Siebel Server, in the event many users log out. The loading of a new MT Server into memory is CPU-intensive, and users may experience a short delay in logging into the Siebel application. In order to prevent this delay, Siebel Administrators may set the Minimum MT Servers parameter equal to the Maximum MT Servers parameter. However, some Siebel Administrators may configure Minimum MT Servers to be lower than the Maximum MT Servers to tune the Siebel application for the normal usage load, while allowing the potential for spikes in user load. Siebel Systems generally recommends that customers set the Minimum MT Servers parameter equal to the Maximum MT Servers parameter for most deployments.
The ratio MaxTasks / MaxMTServers is equal to the Max Number of Tasks running in one instance of a MT Server. When the number of running tasks exceeds the number of tasks that can be supported by the running MT Servers, a new MT Server will be started. Siebel Systems recommends administrators to begin tuning with a ratio of 100:1, assuming an average 30 second think time. If the average user think time is 15 seconds, then the ratio is 50:1 (50% of 100:1). If the average user think time is 60 seconds, then the ratio is 200:1 (200% of 100:1). This will give Siebel Administrators an initial benchmark of performance. Customizations and usage of the Siebel application will dictate whether to increase or decrease these ratios.
Saturday, 4 August 2012
Siebel Remote Diagnostic Agent
When you open any SR with Oracle they expect certain inputs from you which generally includes following files.
- Crash Files
- Log files
- FDR files
- Core files
- Crash.txt
RDA i.e. Remote Diagnostic Agent can be of great use to provide all the required information to Oracle experts at one go. RDA is a less known tool developed in house by Oracle engineers to collect the necessary information about your environment and issue.
Steps to setup RDA in your environment:
1) Download RDA 4.25 from support web. This is .zip file.
https://support.oracle.com/epmos/faces/ui/km/DocumentDisplay.jspx?_afrLoop=30118533417024&id=314422.1&_afrWindowMode=0&_adf.ctrl-state=8uhmykn99_123
Unzip RDA under the SIEBEL_ROOT/siebsrvr directory of the server where you had the crash. This will create directory rda under location SIEBEL_ROOT/siebsrvr
You can refer Doc ID 314422.1 for more details.
2) Download a copy of the solgrabcore.zip file from below location.
https://support.oracle.com/epmos/downloadattachmentprocessor?attachid=477520.1:SGCzip
Now place solgrabcore.sh under the SIEBEL_ROOT/siebsrvr/bin directory.
3) Run the following command from the SIEBEL_ROOT/siebsrvr/rda directory and provide the appropriate input values:
./rda.sh -vT siebel
Note: Please note that all RDA commands and options are case sensitive.
When you run above command it will ask you for following details:
Siebel Server Home (same as SIEBEL_ROOT above)
Application Enterprise Name
Application Server Name
Advanced collection enabled – (Select Yes)
Process Identifier
Core File location – (please verify the directory location of the core file. ensure the entire path including the core file name is provided for this value)
4) As output, zip file will be be created in rda/output directory which will contain all the details. Attach the final RDA*.zip file to the SR. The format of the file will be similar to RDA.RDA_<machine-name>.zip.
This is very handy tool and can save your lot of time that you generally waste in providing inputs to Oracle.
Steps to generate log files for Siebel Tools/Dedicated/Mobile Client
Here are the simple steps to generate Log Files
for Siebel Tools and mobile/Dedicated Client.
1. Right Click on
"My Computer" and select Properties.
2. Select the Advanced tab and open the Environmental Variables window.
3. Under User Variables section, create two Environmental Variables as per following :
a) Variable = SIEBEL_LOG_DIR, Value = C:\LOG
b) Variable = SIEBEL_LOG_EVENTS, Value = ALL
4. Click on Ok.
5. Create a Folder with name "LOG" in "C" drive. This is the folder, where all the logs gets generated.
6. Done.
2. Select the Advanced tab and open the Environmental Variables window.
3. Under User Variables section, create two Environmental Variables as per following :
a) Variable = SIEBEL_LOG_DIR, Value = C:\LOG
b) Variable = SIEBEL_LOG_EVENTS, Value = ALL
4. Click on Ok.
5. Create a Folder with name "LOG" in "C" drive. This is the folder, where all the logs gets generated.
6. Done.
Now restart the Siebel Tools/Mobile/Dedicated client and you will see a "Siebel.log" gets created under C:\LOG folder, which will help you in troubleshooting issues
Siebel Apply and Activate
All of us know, when we do any schema level changes then we have to do Apply & Activate. This post will help you to understand what exactly happens when we do Apply and Activate.
The Apply and Activate buttons appear in the Table and Index sections of Siebel Tools. They are a means to synchronize the logical and physical schema and also to alert other users that changes have been made to the schema.
The logical schema is stored in the S_TABLE, S_COLUMN, S_INDEX and S_INDEX_COLUMN tables in the Siebel database. The physical schema is defined in the RDBMS (IBM DB2, Microsoft SQL Server or Oracle) that is being used.
Developer does the changes in logical schema i.e. in repository. In order to those changes to be propagated to physical schema two things must happen,
1)
Siebel
tools must create DDL statement corresponding to repository level change and fire
that sql to the database.This is exactly what happens when we click Apply button.
2)
Next
step is to press activate button. When you click activate button, Schema version
information stored in table S_APP_VER changes.
Every Siebel component compares schema version information in diccache.dat file with schema information in S_APP_VER table before using schema definitions in deccache.dat file.
So in case you have any new changes and if you have Applied and Activated those changes using Siebel tools, schema version information in S_APP_VER table and dicache.dat will not match and Siebel will recreate diccache.dat file. Newly created diccache.dat file will have latest schema changes. So every time you do any change in logical schema (Repository) you have to perform Apply & Activate.
Saturday, 28 July 2012
Server Busy Error in SIEBEL
"Server you are trying to access is either busy or experiencing
difficulties”
Undoubtedly, for any Siebel admin this is the most common issue to troubleshoot. In this post I will try to list down most possible reasons causing this issue.
Undoubtedly, for any Siebel admin this is the most common issue to troubleshoot. In this post I will try to list down most possible reasons causing this issue.
1) Issue with Database
Check database connectivity by using database client like sqlplus/plsql
developer/Toad
2) Issue with Data source name i.e. DSN
Siebel connects to database using DSN so check
In UNIX:
Setup environment variables, go to bin
directory & run below command
odbcsql
/u sie_app /p ******** /s siebsrvr_CMS
Where,
/u - database user
/p- database
password
/s- Datasource Name
If this is not working then you have to
check .odbc.ini file.
especially driver name & TNS service name (Same service name must be present in tnsnames.ora file)
especially driver name & TNS service name (Same service name must be present in tnsnames.ora file)
If above command errors out then
check following environment variables
echo $ORACLE_HOME
echo $LD_LIBRARY_PATH
echo $TNS_ADMIN
In Windows:
Use ODBC datasource administrator
-> System DSN -> Double click on Data source ->Test
connect
3) Issue with database account
Make sure you can access database with following accounts
1) Anon user : In case of DB
authentication
2)
SADMIN/LDAP
USER: In case of LDAP or SSO Authentication (assuming you use SADMIN/LDAP
USER as common login to connect to database )
3) Check anon user and SADMIN/LDAP user is
present in S_USER table.
select * from S_USER where login
like ‘SADMIN’
select * from S_USER where login like ‘ANONUSR’
4) Check Siebel services
Ps –ef | grep sieb
ps –ef | grep siebsvc
Check Siebel server & Gateway is
running.
list_ns
list_server all
5) Check SC broker & AOM status
set server siebapp
list comp scbroker show CC_ALIAS, CP_DISP_RUN_STATE
list comp SSEObjMgr_enu show CC_ALIAS, CP_DISP_RUN_STATE
list tasks for comp SSEObjMgr_enu show TK_TASKID, TK_DISP_RUNSTATE,
TK_LABEL
list tasks for comp scbroker show TK_TASKID, TK_DISP_RUNSTATE, TK_LABEL
6) Check port 2321 of application server
telnet tsgsq2902 :2321 (from web server)
netstat -an | grep 2321 (from
application server)
7) Check core services are running
cd $MWHOME/bin
./mwadm status
Or check status of process regss , watchdog ,mwrpcss etc
8) Check data source definition
srvrmgr:siebapp> List param DSConnectString for named
subsystem ServerDataSrc show PA_ALIAS, PA_VALUE
9) Check CPU/Memory/Mount space utilization
df -hk
top –n 0
prstat –a 5 5
10) Try using vanilla Siebel.srf file
11) Try using backu[ copy of siebns.dat file
13) Check lbconfig.txt file & eapps.cfg to
make sure requests are reaching to SCbroker
a)
lbconfig.txt
location specified correctly in eapps.cfg under communication management
section
b)
virtual
host value must be set to true
c)
server
connect strings must be given properly in lbconfig.txt file
d)
object
manager connect string in eapps.cfg must contain value Virtual host
14) Check application server log files, WEB
instance log, SWSE logs, SSO agent logs
15) If it is newly installed environment then
check environment by using EVT
16) Make sure that all the mounts including File system are available.
17) Restart Application Server
delete .osdf file make sure
that .shm file is getting deleted after
stopping server, if not, delete it manually.
18) Take web server bounce
19) Take clean bounce to recreate .svc file
Refer article http://www.siebeloracle.com/how-to-take-clean-bounce-of-siebel-server/
for clean bounce
20) Verify messages in /var/adm/messages
21) Physical host reboot
This
should be the last resort, if nothing else works. Server reboot will open
clogging of ports and will restart all the OS processes.
Friday, 27 July 2012
Siebel Packager
Hello Friends,
Sometime back I got chance to create mobile client packager.
In this post I will explain procedure of creation of packager, in next few days
I will also write separate article on Siebel anywhere.
What is packager?
The Siebel Packager utility allows the Siebel administrator
to assemble the Siebel client executable program and other installed files,
including your custom configuration, into a customized installation package
that is tailored to your needs. Siebel Packager packages installations for
Siebel Mobile or Dedicated Web Client.
You can access/download the document from below link.
Sunday, 15 July 2012
Siebel 8.2.2 Installation Changes
Hi Friends,
Recently I got chance to install Siebel 8.2.2, most of the
installation steps are similar to 8.1.x with few interesting differences. I am
going to pinpoint those differences in this post.
1) It supports
windows 64 bit
2) ImageCreator.exe
is no more available for creation of installation image. You have to use
snic.bat
3) You have to run setup.bat(Windows) or
./runinstaller(Unix/Linux) to invoke installer
4) It uses OUI
(Oracle universal installer wizard) for installation.
One of the advantages of OUI is that it supports cloning
5) Configuration tool will not be invoked automatically after installation, you have
One of the advantages of OUI is that it supports cloning
5) Configuration tool will not be invoked automatically after installation, you have
to invoke it
explicitly.
6) To prevent session
hijacking, session IDs in cookies are encrypted using key given in epps.cfg
7) 8.2.2 license keys
are not available on licensecodes.oracle.com.
8.1 all inclusive keys will work just fine with Public Sector 8.2.2
8.1 all inclusive keys will work just fine with Public Sector 8.2.2
Friday, 6 July 2012
Siebel Component synchronization
When to do synchronization?
You need to synchronize batch-mode Siebel Server components between the Siebel Gateway Name Server and the database whenever you:
Why to synchronize?
For batch mode components to function properly they should have their definitions available in S_SRM_ACTION and S_SRM_ACT_PARAM tables. When we synchronize any batch mode component, Siebel flushes definition of that particular batch mode component from siebns.dat file to S_SRM_ACTION and S_SRM_ACT_PARAM tables.
How to synchronize?
-- From Siebel server manager.
smgr> sync comps
-- From GUI
1. From the application-level menu, choose Navigation > Site Map > Administration - Server Configuration.
Siebel MainWin Processes
Significance of MainWin Processes in Siebel
Siebel is written in c ++ and it was originally developed for windows platform only.
Mainsoft is the application porting platform which rapidly ported entire Siebel application logic engine to UNIX. So MainWin binary (mwadm) gets installed during Siebel server installation on UNIX or Linux based environments.
You can see Mainwin installation path in siebenv.sh file as $ MWHOME.
MainWin Processes:
1) regss:
regss is the registry service of MainWin. This service is in charge of manipulating the registry file which contains system and application information.
2) mwrpcss:
mwrpcss processes the RPC (Remote Procedure Calls) and COM (Component Object Model)requests for MainWin.
3) watchdog:
watchdog ensures that both regss and mwrpcss daemons are running.
All Siebel server components calls/uses above three processes during run time.
When we stop Siebel server, MainWin processes should ideally be stopped.
It is good practice to check status of MainWin processes after server shutdown, if processes are running even after shouting down the server , stop processes manually using below command
Go to /siebsrvr/mw/bin directory and run command ./mwadm stop
Also after starting Siebel server these processes ideally should come up, if not start them manually using ./mwadm start
You can check status of Mainwin services using command ./mwadm status
If MainWin processes get corrupted or killed while starting Siebel server, siebsvc process will get started but no other process will start i.e, Siebel server will be up but no component will take anyrequest because no process for any component will get created. In this case we have to restart theMainWin processes first and then we should start the Siebel servers.
Note: MainWin processes must not be shutdown or killed while Siebel server is running.
Thursday, 21 June 2012
Siebel Administrator Roles & Responsibilities
Guys,
I am trying to list down Siebel admin roles and
responsibilities. Please feel free to
suggest/correct/add if I am missing anything.
Siebel admin roles & responsibilities:
1.
SIEBEL
server installation & configuration, Patch management
2.
Siebel
version upgrade
3.
Setting
up Siebel tools , Mobile/dedicated client
4.
SRF,
Repository migration. DDL synch.
5.
Performance
tuning
6.
Supporting
Production environment which includes
·
Maintaining
high application availability
·
Planning
and co-coordination of production release.
·
Daily
health checks which includes regularly checking status of servers &
components. Checking status of JOBs/RCRs/ Tasks. Server resource monitoring(CPU/Memory/Disk
space)
·
Performance
tuning
·
supporting
all planned & unplanned outages
7.
Supporting Test and Development environments which includes
·
Setting
up tools/mobile client for developers
·
Extracting
local databases for developers
·
Migrating
SRF/Repository from Development to Test environment
·
Deploying
non repository items
·
Supporting
performance testing in Test(QA) environment
·
supporting
all planned & unplanned outages
8.
Set up and support Siebel remote. This
includes registering user as mobile client, extracting local database, creation of packager ,
upgrade kits etc
9.
Set
up email profiles. Configuring and managing communication management component
group
10.
Configuring
& managing Workflow Management component group.
Create WF monitor agents as per requirement.
11.
Integrating
other applications with Siebel. Mainly OBIEE/BIP/Web Methods. This includes
configuring symbolic urls, WSDL imports/exports etc.
- Installing and configuring actuate server
- Installing and configuring document server
- Database refresh activity
15.
Setting
up UCM(Data Hub)
16.
Setting
up Oracle policy automation
17.
Setting
up SSO/LDAP authentication
18.
Automation
of daily migration/monitoring activities by writing shell scripts or batch jobs
19.
Resolving
all adhoc issues, if issue is not related to Siebel then assign it to correct
work-group.
20.
In
case of issues preparing RCA & RCCA documents
21.
Keep
all stake holders updated with progress in case of issues as per SOP.
22.
Opening
SR with oracle in case of critical issues
23.
Co-coordinating
with different teams
Hope this will help.
Subscribe to:
Posts (Atom)