Middleware was the fourth hottest skill to get hired in 2017, and there is no reason to go down in the coming years.
If you recently started working on WebSphere or any other product suite of Middleware, then one of the very first things to get familiar is widely used Linux commands.
In this article, I will talk about some of the often-used Linux commands by WebSphere or Middleware administrator on a daily basis.
Finding SystemOut.log
If you are working on the existing environment and if an administrator has redirected SystemOut.log to some other location then it would be challenging to find it.
#find / -name SystemOut.log
Tips: if you have multiple file systems then it may take time to search. So best would be to replace / with the actual file system where you think the log would be. Let’s say you believe log is in /opt file system so you can do this.
#find /opt –name SystemOut.log
Know which process is holding a specific port number
Quite often you will have to deal with port conflict issues, especially in the shared environment.
If there is a situation to find out which process is holding port number then here is how you can know.
#netstat –anlp | grep 443
Ex
[root@Chandan ~]# netstat -anlp | grep 443 tcp 0 0 0.0.0.0:443 0.0.0.0:* LISTEN 20924/nginx [root@Chandan ~]#
Note: Above example shows nginx with PID 20924 is holding 443 port.
Server boot time
If you are performing auto-startup troubleshooting and would like to know when the server was rebooted, you can use this command.
#who –b
[root@Chandan ~]# who -b system boot Jun 28 01:11 [root@Chandan ~]#
who -b command will give you the exact date and time of server reboot.
Alternatively, you may also use up time to check how long the server is up.
[root@Chandan ~]# uptime 01:20:27 up 14 days, 9 min, 1 user, load average: 0.00, 0.00, 0.00 [root@Chandan ~]#
Check CPU/Memory utilization in runtime
If you are having a performance issue, then you might want to know the current CPU/Memory utilization.
This will help you to find out which process is taking high CPU/Memory in real-time.
#top top - 01:16:21 up 14 days, 5 min, 1 user, load average: 0.00, 0.00, 0.00 Tasks: 70 total, 1 running, 69 sleeping, 0 stopped, 0 zombie Cpu(s): 0.0%us, 0.0%sy, 0.0%ni, 99.7%id, 0.0%wa, 0.0%hi, 0.3%si, 0.0%st Mem: 502220k total, 454920k used, 47300k free, 143476k buffers Swap: 0k total, 0k used, 0k free, 245412k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 29121 root 20 0 15008 1260 992 R 0.3 0.3 0:00.02 top 1 root 20 0 19232 1136 860 S 0.0 0.2 0:25.18 init 2 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd 3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/0 4 root 20 0 0 0 0 S 0.0 0.0 0:01.21 ksoftirqd/0
Tips: look for the CPU/Memory section for the first few PID to find out the utilization.
Alternatively, you may also use the free command to find out total and free memory.
#free –m
[root@Chandan ~]# free -m total used free shared buffers cached Mem: 490 444 46 0 140 239 -/+ buffers/cache: 64 425 Swap: 0 0 0 [root@Chandan ~]#
As you can see above, there is 490 MB total memory, and only 46 MB memory is available.
There is another command called SAR (System Activity Report), which is also very helpful to find the CPU and Memory stats.
To check the CPU utilization
#sar
To check the Memory utilization
sar -r
Kill the process
Sometimes the process doesn’t stop gracefully if it’s hung or defunct. In this scenario, you can kill the process manually.
#kill PID
If above doesn’t help, you can use -9 to kill the process forcefully.
#kill -9 PID
Note: PID is your process ID
Compression & Extraction
Most often you will have to deal with compressing the files as housekeeping activity for a file system.
Compression
gzip command can be used to compress the files.
#gzip filename
Tips: if you have multiple files to be compressed, you can use gzip * which will compress all the files available in that working directory.
Extraction
gunzip command will help you to extract the gz file.
#gunzip filename
Tips: you can use gunzip * which will help you to extract all gz file in that working directory.
Total CPU, Memory, File System
Often asked to provide server information, if you are working on migration or capacity planning.
Here is the quick command to help you to find out total CPU, Memory, and File system details.
CPU information
Find out CPU Cores, MHz, CPU manufacturer, Model Name and much more by using
#cat /proc/cpuinfo
Tips: if you have a high-end server then output of the above command will be long. So you can use grep to filter out the required information. Ex, just to find out cores, you can use
#cat /proc/cpuinfo | grep cores
Memory information
To find out the total available memory, you can use one of the following commands.
First one….
#free –G
This will show you total, free & cached memory
Second one…
#cat /proc/meminfo
This will show you much more information along with total memory.
File System information
To find out file system size and usage, you can use df commands.
#df –h
[root@Chandan tmp]# df -h Filesystem Size Used Avail Use% Mounted on /dev/vda1 20G 1.6G 18G 9% / tmpfs 246M 0 246M 0% /dev/shm [root@Chandan tmp]#
Including –h will give you output in GB which is easy to understand.
Check out IP, Subnet Mask, MAC address and errors
Probably, one of the most widely used commands to find out IP related information.
[root@Chandan tmp]# ifconfig eth0 Link encap:Ethernet HWaddr 04:01:5A:25:57:01 inet addr:128.199.100.162 Bcast:128.199.127.255 Mask:255.255.192.0 inet6 addr: fe80::601:5aff:fe25:5701/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:1491330 errors:0 dropped:0 overruns:0 frame:0 TX packets:1636419 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:306418374 (292.2 MiB) TX bytes:274350737 (261.6 MiB) [root@Chandan tmp]#
As you can see above, ifconfig will show the IP addresses, Ethernet details, a hardware address (MAC), subnet mask, errors, and other information. This is an extremely useful handy command if you are looking for this information.
Tips: you can use –a with ifconfig to show all available Ethernet details. Ex:
#ifconfig –a
Network commands like wget, telnet, traceroute
If you are doing application connectivity troubleshooting then most likely you will need to use these network commands.
Check if you can access particular URL from a server
You can quickly confirm if there is any connectivity issue on your server by using wget command. Ex: if you need to check if the server can access an external website like https://geekflare.com or not, you can use below.
[root@Chandan tmp]# wget geekflare.com --2015-07-12 02:52:56-- https://geekflare.com/ Resolving geekflare.com... 104.28.23.60, 104.28.22.60 Connecting to geekflare.com|104.28.23.60|:80... connected. HTTP request sent, awaiting response... 200 OK Length: unspecified [text/html] Saving to: `index.html' [ <=> ] 65,435 --.-K/s in 0.005s 2015-07-12 02:52:56 (13.4 MB/s) - `index.html' saved [65435] [root@Chandan tmp]#
Tips: above you can see HTTP response code is 200 means there is no issue in connectivity.
Verify if the server can connect to backend service with the particular port number
If you are connecting to some other application like web service and need to verify if you can reach them, then you can use telnet command. This is very useful for a connectivity test.
In the below example, I have checked if geekflare.com on 443 port can be reached or not.
[root@Chandan tmp]# telnet geekflare.com 443 Trying 104.28.23.60... Connected to geekflare.com. Escape character is '^]'.
If you see “Connected” then that confirms there is nothing wrong with connectivity/firewall. However, if you see connection failed then you know, there is something like a firewall blocking your connection.
Tracing connection details
This may not be used all the time but extremely helpful when you have a latency issue or just want to find out the connection path between your server to the destination.
Below example is to show the network path from my server to geekflare.com
[root@Chandan tmp]# traceroute geekflare.com traceroute to geekflare.com (104.28.23.60), 30 hops max, 60 byte packets 1 128.199.127.253 (128.199.127.253) 5.110 ms 5.061 ms 128.199.127.254 (128.199.127.254) 0.418 ms 2 103.253.144.237 (103.253.144.237) 5.153 ms 0.463 ms 103.253.144.241 (103.253.144.241) 8.009 ms 3 as13335.singapore.megaport.com (103.41.12.6) 4.822 ms 13335.sgw.equinix.com (202.79.197.132) 4.819 ms as13335.singapore.megaport.com (103.41.12.6) 4.490 ms 4 104.28.23.60 (104.28.23.60) 4.454 ms 4.427 ms 4.366 ms [root@Chandan tmp]#
Ownership modification
If you are dealing with multiple users on a server and having root permission too then most likely once in a while, you will screw with permission/ownership. Well, not to worry its part of learning.
Here is the quick way to change the ownership or permission.
Change ownership
To change ownership of a particular file, you can use the chown
command as below.
#chown user:group error.log
Tips: above will change ownership of error.log to mentioned user and group. If you have a folder, then you can use –R
, which will change recursively to all the files within the folder. Ex:-
#chown –R user:group somefolder
I hope the above commands help you with your work. If you are looking to learn more sysadmin skills then check out these resources.