WebLogic Interview Questions
How do you differentiate between a server hang and server crash issue?
When a Server crahes, the JAVA process no longer exists. When the Server is hung, it stops responding.
We can use the weblogic.ADMIN utilty to ping the server. In case of a hang situation we can take multiple thread dumps and analyze the cause of hang.
What can be the various reasons for a server crash?
- Native IO
- SSL Native Libraries
- Supported Configuration
- JDBC Driver issue
How do you troubleshoot a crash?
- JVM crash generates a hs_err_pid file. We need to look into the stack trace of the hs_err_pid file .
- If the thread is from a native io, we need to disable native io.
- if the stack trace is from the driver, we need to get in touch with the drive team.
- Quite possibly its a problem with driver. Changing the type of driver can be a workaround.
- If the thread shows it coming from an optimized code, we can turn of optimization.
- If the stack is from native calls of application, its a bug with the application and it has to b modified.
Ho do you troubleshoot Server Hang?
We can use java weblogic.Admin PING to check if we get a normal response.
We need to take multiple thread dumps with kill -3 pid on unix and CTLR Break on Windows.
Analyze the thread dump to find the root cause.
What can be the reasons of Server hang?
Memory leak, databse query taking a long time to return, Deadlock.
What is memory leak?
Memory leak is when objects are not romved from the heap even when they are not required.
What are the various causes for OUT OF MEMORY?
- Insufficient heap size, not able to match the extra load.
- Objects licing too long, like HTTP Sessions.
- Memory leak in application code.
- Full GC not happening due to JVM Bug.
How to troubleshoot and overcome such issues?
- Gather memory data by enabling GC verbose.
- If its due to Http Session, timing out http session after certain interval might help.
- Look into the code for jdbc connection handling.
- Optimizing the heap size according to the load.
When does High CPU Usage occur?
It occurs when one process or one thread utilizes unexpectedly high proportion of CPU.
How to troubleshoot it?
In Solaris environment, we need to take pstack and prstack and see what the threads are doing.
In Windows we need to use pslist and process explorer.
What is Clustering and what is achieved through it?
Clustering is the grouping together of servers for the purpose of high availability and scalability.
Load balancing and Failover is achieved.
How does Cluster Communication Happen?
Members of the Cluster communicate over the Cluster Multicast IP and Port by sending periodic heart beat messages.
What is the difference between the Sun JVM and BEA JRockit JVM?
The most well know JVM is the implementation from Sun. The Sun JVM is called HotSpot. The Sun JVM is shipped in the Java Developer’s Kit (JDK) and Java Runtime Environment (JRE) from Sun.
The BEA JRockit JVM from BEA systems is optimized for reliability and performance for server side applications. To achieve this, BEA JRockit JVM uses technologies such as code generation, hot spot detection, code optimization, advanced garbage collection algorithms and tight operating system integration.
TUning JVM Parameters.
If you have a single processor, single thread machine then you should use the serial collector (default for some configurations, can be enabled explicitly for with -XX:+UseSerialGC). For multiprocessor machines where your workload is basically CPU bound, use the parallel collector. This is enabled by default if you use the -server flag, or you can enable it explicitly with -XX:+UseParallelGC. If you’d rather keep the GC pauses shorter at the expense of using more total CPU time for GC, and you have more than one CPU, you can use the concurrent collector (-XX:+UseConcMarkSweepGC). Note that the concurrent collector tends to require more RAM allocated to the JVM than the serial or parallel collectors for a given workload because some memory fragmentation can occur.
How do you do performance tuning of WLS?
It can be categorized in 4 parts.
a. Application Tuning.
jsp precompilation, ejb pool size cache..
- OS Tuning
Setting tcp ip parameter.
- Core Server Tuning.
tune workmanager, tune chuck size and chunck pool size, using performance packs, conenction backlog buffering.
- JVM Tuning
tuning gc strategy, monitoring garbage collection..
What is the difference between Development mode and Production mode of Weblogic Server?
- The default JDK for development domain is Sun Hotspot.
- You can use the demo certificates for SSL.
- Auto deployment(to admin server only) is enabled.
- Server instances rotate their log files on start-up.
- Admin Server uses an automatically created boot.properties during start-up.
- The default maximum capacity for JDBC Datasource is 15.
- The debugFlag which is used to start the WebLogic Workshop Debugger is enabled.
- In Development Mode any configuration change being done by a user doesn’t need him to take a Lock and Edit session.
- Availability of web service test client.
- Nodemanger username and password: Default Admin credentials.
- Availability of Classloader Analysis Tool: Yes.
- Default start parameters when using Sun JDK and the default startWebLogic script : java -client -Xms256m -Xmx512m -XX:CompileThreshold=8000 -XX:PermSize=128m -XX:MaxPermSize=256m.
- The default JDK for production domain is JRockit.
- If you use the demo certificates for SSL a warning is displayed.
- Auto deployment(to admin server only) is disabled.
- Server instances rotate their log files when it reaches 5MB.
- Admin Server prompts for username and password during start-up.
- The default maximum capacity for JDBC Datasource is 25.
- The debugFlag which is used to start the WebLogic Workshop Debugger is disabled.
- In Production Mode the user needs to procure a Lock and Edit session before trying to make any configurational changes.
- No Availability of web service test client.
- Nodemanger username and password: Randomly generated
- Availability of Classloader Analysis Tool: No.
- Default start parameters when using Sun JDK and the default startWebLogic script : java -server -Xms256m -Xmx512m -XX:MaxPermSize=256m.
What is HTTP tunneling? How can we configure it on Weblogic?
HTTP tunneling provides a way to simulate a stateful socket connection between WebLogic Server and a Java client when your only option is to use the HTTP protocol. It is generally used to tunnel through an HTTP port in a security firewall. HTTP is a stateless protocol, but WebLogic Server provides tunneling functionality to make the connection appear to be a regular T3Connection.
Steps to configure Http tunneling.
Login into the Admin Console, click on the server on which you want to enable he Http Tunneling feature
Click on the Protocols tab ? General ? check the “Enable Tunneling” check box.
Now you can communicate with the JVMs (Server Instances) using protocols other than t3
What is the difference between T3 and HTTP protocol?
WebLogic uses the T3 protocols for internal and external connections to the servers. The T3 protocol often is used in WebLogic’s implementation of RMI. Proprietary of WebLogic Server.
Http protocols are used primarily for HTTP communication between the browser and the web server. Standard follows the W3C (World Wide Web Consortium).
Note: All of these protocols are, by default, multiplexed over the same connection to the server’s address and port. So you can access a web page hosted by the server using a URL such as http://host:port/page.jsp. An external client can set up an initial JNDI context to a server using the URL t3://host:port/. All that has changed is the protocol over which the client must communicate with the server.