Saturday, December 19, 2009

Netstat

List The Open Ports And The Process That Owns Them
netstat -lptu

netstat command to find open ports
# netstat --listen

Display open ports and established TCP connections:
# netstat -vatn

For UDP port try following command:
# netstat -vaun

If you want to see FQDN, remove -n flag:
# netstat -vat

Display list of open ports
# lsof -i

To display all open files, use:
# lsof

To display all open IPv4 network files in use by the process whose PID is 111, use:
# lsof -i 4 -a -p 111

Get Detailed Information About Particular IP address using netstat

This is useful to find out if your server is under attack or not. You can also list abusive IP address using this method.
# netstat -nat | awk '{print $6}' | sort | uniq -c | sort -n
      1 CLOSE_WAIT
      1 established)
      1 Foreign
      3 FIN_WAIT1
      3 LAST_ACK
     13 ESTABLISHED
     17 LISTEN
    154 FIN_WAIT2
    327 TIME_WAIT

Dig out more information about a specific ip address:
# netstat -nat |grep {IP-address} | awk '{print $6}' | sort | uniq -c | sort -n
      2 LAST_ACK
      2 LISTEN
      4 FIN_WAIT1
     14 ESTABLISHED
     91 TIME_WAIT
    130 FIN_WAIT2Busy server can give out more information:

# netstat -nat |grep 202.54.1.10 | awk '{print $6}' | sort | uniq -c | sort -n
  15 CLOSE_WAIT
  37 LAST_ACK
  64 FIN_WAIT_1
  65 FIN_WAIT_2
1251 TIME_WAIT
3597 SYN_SENT
5124 ESTABLISHED

Get List Of All Unique IP Address
To print list of all unique IP address connected to server, enter:
# netstat -nat | awk '{ print $5}' | cut -d: -f1 | sed -e '/^$/d' | uniq

To print total of all unique IP address, enter:
# netstat -nat | awk '{ print $5}' | cut -d: -f1 | sed -e '/^$/d' | uniq | wc -l
449

Find Out If Box is Under DoS Attack or Not
If you think your Linux box is under attack, print out a list of open connections on your box and sorts them by according to IP address
# netstat -atun | awk '{print $5}' | cut -d: -f1 | sed -e '/^$/d' |sort | uniq -c | sort -n
    1 10.0.77.52
      2 10.1.11.3
      4 12.109.42.21
      6 12.191.136.3

Display Summary Statistics for Each Protocol
# netstat -s | less
# netstat -t -s | less
# netstat -u -s | less
# netstat -w -s | less
# netstat -s

Display Interface Table
You can easily display dropped and total transmitted packets with netstat for eth0:
# netstat --interfaces eth0

The command for finding if you are under DoS attacks:
# netstat -atun | awk '{print $5}' | sed -n -e '/[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}/p’ | sed -n -e '/ESTABLISHED/p' | sed ’s/::ffff://’ | cut -d: -f1 | sort | uniq -c | sort -n

Find

Find

Syntax
# find   location  test  options   criteria_to_match   action_to_perform

Finding files
To find all files having txt extension *.txt
# find / -name *.txt

To find file location
# find / -name syslog.conf

Files owned by a user
# find / -user root

Files by type
# find / -type d

l—symbolic link
d—directory
b—block (buffered) special
c—character (unbuffered) special
p—named pipe (FIFO)
s—socket

File according to date and time
# find / -atime +3
-atime +3: All files that were last accessed more than 3 days ago

mtime—the time that the contents of a file were last modified 
atime—the time that a file was read or accessed
ctime—the time that a file’s status was changed

-n returns less than n 
+n returns greater than n 
n, by itself,returns exactly n matches

Files by size(larger than 5 MB)
# find / -size +5000000c

Finding by Permission and Ownership
# find / -type f  -perm a=rwx 
or 
# find / -type f  -perm 777

Finding files and perform some action (delete)
# find . -type f -perm 777 -exec ls -l *.* {} \;

Locate command
To find the location of files & directories
# locate *.txt

To update the database
# updatedb

grub

Fix grub issues

Boot from linux DVD or CD into rescue mode
boot: linux rescue

Linux installation will be available at special directory called /mnt/sysimage

Prepare system for grub installation, chroot command allows to run rest of all *COMMAND* with root directory set to NEWROOT called /mnt/sysimage
# chroot /mnt/sysimage
# cd /boot/grub

Check bootloader installation location
# grep '#boot' grub.conf
boot=/dev/sda

Reinstall Grub into sda
# grub-install /dev/sda

Reboot
# reboot

Audit

Linux audit files to see who made changes to a file

Package name audit
# yum install audit

auditctl - a command to assist controlling the kernel’s audit system. You can get status, and add or delete rules into kernel audit system.
ausearch - a command that can query the audit daemon logs based for events based on different search criteria.
aureport - a tool that produces summary reports of the audit system logs.

Start audit
# /etc/init.d/auditd start

Set a watch on a file for auditing
# auditctl -w /etc/passwd -p war -k password-file

Where,
-w /etc/passwd : Insert a watch for the file system object at given path i.e. watch file called /etc/passwd
-p war : Set permissions filter for a file system watch. It can be r for read, w for write, x for execute, a for append.
-k password-file : Set a filter key on a /etc/passwd file (watch). The password-file is a filterkey (string of text that can be up to 31 bytes long). It can uniquely identify the audit records produced by the watch. You need to use password-file string or phrase while searching audit logs.
In short you are monitoring (read as watching) a /etc/passwd file for anyone (including syscall) that may perform a write, append or read operation on a file

Add a watch on "/etc/shadow" with the arbitrary filterkey "shadow-file" that generates records for "reads, writes, executes, and appends" on "shadow"
# auditctl -w /etc/shadow -k shadow-file -p rwxa

Find out who changed or accessed a file /etc/passwd
# ausearch -f /etc/passwd 
or
# ausearch -f /etc/passwd -i | less

Where,
-f /etc/passwd : Only search for this file 
-i : Interpret numeric entities into text. For example, uid is converted to account name

SSH

 Daemon sshd 
 Port 22
 Config /etc/ssh/sshd_config


Default Config Files and SSH Port
OpenSSH server configuration file
/etc/ssh/sshd_config
OpenSSH client configuration file
/etc/ssh/ssh_config
Users ssh configuration directory
~/.ssh/
Lists the public keys (RSA or DSA) that can be used to log into the user’s account
~/.ssh/authorized_keys
If the below file exists, sshd refuses to let anyone except root log in
/etc/nologin
Access controls lists that should be enforced by tcp-wrappers are defined here. 
/etc/hosts.allow and /etc/hosts.deny
SSH default port : TCP 22 

Use SSH Protocol 2

sshd_config file configurations
Only allow root and xyz user to use the system via SSH, add the following to sshd_config:
AllowUsers root xyz
# Alternatively, you can allow all users to login via SSH but deny only a few users, with the following line:
DenyUsers abc foo
# Configure Idle Log Out Timeout Interval (sshd_config)
ClientAliveInterval 300
ClientAliveCountMax 0
# Disable root Login via SSH
PermitRootLogin no
# Enable a Warning Banner
Banner /etc/issue
# Change SSH Port and Limit IP Binding
Port 300
ListenAddress 192.168.1.5
ListenAddress 202.54.1.5
# Disable Empty Passwords
PermitEmptyPasswords no
# Use Log Analyzer
LogLevel INFO

Verify your sshd_config file before restarting / reloading changes:
# /usr/sbin/sshd -t

SSH allows administrators to set an idle timeout interval

Find ClientAliveInterval and set to 300 (5 minutes) as follows:
# vi /etc/ssh/sshd config 
ClientAliveInterval 300
ClientAliveCountMax 0

Save and close the file. Restart sshd:
# service sshd restart

Running a remote command
# ssh username@host command1;command2

Allow SSH without password
Server – login to other system without password
Client – allows user from server without password

Server configuration
# ssh-keygen -t dsa
# cd .ssh
# scp id_dsa.pub root@server:~/.ssh/authorized_keys

Boot Process

Stages of Boot process
 System Startup Bios
 Stage1 Bootloader MBR
 Stage2 Bootloader GRUB 
 Kernel & initrd Linux
 init User-space

  • BIOS Initialization
  • Boot Loader resides in MBR, load from boot partition
  • Kernel Initialization Device detection, device driver initialization, Mount root filesystem read only, Loads initial process (init)
  • /etc/rc.d/rc.sysinit - Ask I for interactive mode (activate selinux, set clock, enable swap, set hostname, root filesystem check, activate RAID, LVM, disk quota)
  • /etc/rc.d/rc initialize default run level as per inittab file entry
  • start rcX.d as per run level
  • /etc/rc.d/init.d contains all service files
  • /etc/rc.d/rc.local run after run level specific sctipts, common place for custom modification. Run each time system enters a run level
If root filesystem is mounted as read only in single user mode, to remount in rw
#  mount –o rw,remount /
#  mount –o remount –w /

File system check without prompting
#  fsck –y

NFS

Network file system is both a protocol and file system for accessing and sharing file systems across a computer network using Linux.
NFS v4 is used in modern Linux distributions. It offers performance improvements, mandates strong security, and introduces a stateful protocol etc.

NFS Server configuration file
/etc/exports – file enumerates the filesystem exported through NFS
share hostname|ipaddress|domain|*(options)

options include
sync                    Reply to requests only after the changes have been committed to stable storage
ro    exports as read-only
rw    reading and writing (default)
no_root_squash    allows normal access by root
noaccess    prevent access
secure    remote access originate from privileged port

To save new changes to export file
# exportfs -a
To remove entries from exports table
# exportfs -u

Export a directory with NFS
To export or share directory called /data
Edit the file /etc/exports, this file serves as the access control list for file systems which may be exported to NFS clients
Add config directive to exports file
/data *(rw,sync)

Restart the nfs service:
# /etc/init.d/nfs restart
or
# service nfs restart

NFS Client configuration
Client computer need to mount file system using mount command or /etc/fstab file
# mkdir /data
# mount -t nfs nfsservername|ip:/mountpoint /data
Add an entry in /etc/fstab
nfsservername|ip:/mountpoint /data nfs defaults 0 0
To list the exported filesytem
# Showmount –e hostname

Mount NFS filesystem in two different directories on same system
NFS Server : nfsserver:/data
Mount to client dirs /data and /backup

Mount command has bind option to remount part of the file hierarchy somewhere else
First mount to /home/data
# mount -t nfs4 nfsserver:/data /data

Now bind /home/data to /backup
# mount --bind /data /backup

NAS (Network attached storage) also supports NFS configuration. Access NAS server using NFS protocol
NFS Daemons, In order to use NFS you need to run portmap service and rpc.statd and rpc.lockd daemons
# chkconfig portmap on
# chkconfig nfslock on
# /etc/init.d/portmap start
# /etc/init.d/nfslock start

To access NAS from client
# mkdir /backup
# mount -o tcp 202.54.20.111:/mountpoint /backup

Add an entry in /etc/fstab
202.54.20.111:/mountpoint /backup nfs defaults 0 0

NTP

The Network Time Protocol package contains utilities and daemons that will synchronize your computer's time to Coordinated Universal Time (UTC) via the NTP protocol and NTP servers. 

The NTP packageincludes ntpdate (a program for retrieving the date and time from remote machines via a network) and ntpd (a daemon which continuously adjusts system time).

NTP Server Configuration
Your NTP server contacts a central NTP server (Public Server located at ntp.org, to obtain accurate time data).
The server then allows other machines on your network to request the time data.

Sample Network
192.168.1.10           ==> NTPD Server
201.55.11.1            ==> Remote NTP server
192.168.1.0/24         ==> NTP clients

# vi /etc/ntp.conf
restrict default ignore
//Above will deny all access to any machine, server or client

restrict 202.55.11.1 mask 255.255.255.245 nomodify notrap noquery
server 202.55.11.1

//Configure NTP clients to access your NTP Server
restrict 192.168.1.0 mask 255.255.255.0 nomodify notrap
//Allow NTP clients to access the Server

NTP Client configuration
# vi /etc/ntp.conf
server 192.168.1.100

Determining If NTP Is Synchronized Properly
# ntpq -p

update NTP manually, but ntp daemon should be off
# ntpdate servername

Local date & time
Date command displays the date and time of the system
# date nnddhhmm[[cc]yy][.ss]
where,
nn = month of the year (01 to 12) 
dd = day of the month (01 to 31) 
hh = hour of the day (00 to 23) 
mm = minute of the hour (00 to 59> 
cc = The first to digits of the year 
yy = The last two digits of the year 
.ss = The seconds 

The hardware clock is the clock that runs in you PC hardware even if you disconnect it from the main power supply, this is because it has a lithium battery.
hwclock command used to set or get the time of you hardware clock

Set the clock you August 8th, 2007 at 21:08 and will tell your clock that is the local time
# hwclock --set --date='08/18/07 21:08:40' --localtime

To check
# hwclock --show

About Linux

Linus Torvalds wrote the first Linux kernel way back in 1991

Linux Principle
  • Everything is file
  • Configuration data stored in text file
Uniqueness of Linux
  • Multitasking capability
  • Multi-user capability
  • Portability
Linux Architecture
  • Kernel is the heart of the operating system and it controls the hardware
  • The Shell acts as an interpreter between the user and the computer
  • Tools are grouped into categories for certain functions, such as word processing, business applications

File System - Disk Quota

Disk space can be restricted by implementing disk quotas which alert a system admin before a user consumes too much disk space or a partition becomes full.

Configuring Disk Quotas

Enable quotas per file system by modifying /etc/fstab
# vi /etc/fstab
/dev/VG0/LV2 /home ext3 defaults,usrquota,grpquota 1 2
/dev/VG0/LV3 swap swap defaults 0 0

Remount the file system
# mount -o remount /home

Create quota database file (to generate aquota.user & aquota.group files)
# quotacheck -cug /home
option c for create quota file, u for user quota file & g for group quota file

Assigning quotas per user
# edquota username
add soft and hard values

Assigning quotas per group
# edquota -g groupname

Assigning quotas per filesystem
# edquota -t

Now enable quotas
# quotaon -vug /home

Reporting on disk quotas
# repquota /home

File System - Access Control List

Used to grant access to multiple users

Mount with ACL option
# mount –o remount,acl /directory_name

List assigned ACL
# getfacl file|directory_name

Set ACL for user
# setfacl –m u:username:rwx file

Set ACL for group
# setfacl –m g:groupname:rwx file

Set ACL only for Directory
# setfacl –m d:u:username:rwx directory_name

Remove ACL
# setfacl –x u:username file|directory_name

Entries appear in ACL
user::perm - set permission for file owner
user::username:perms  - set permission for a specific user
group::perms - set permission for group that own the file
group::groupname:perm - set permission for a specific group
other::perms - set permission for all others  
mask::perms - set permission for all but owner and other

File Permissions

File Permissions

  • Every file is owned by a user and group
  • Three Access Categories are user, group, others
  • Three Permission types are read, write & execute
  • suid – command run with permission of owner
  • sgid – command runs with group affiliation
  • sticky bit – special restriction on deletion of files other than owner
  • umask 002 – list permission to withhold (default value)
Permission types

 Letter Numeric Permission
 r 4 read 
 w 2 create, write & remove files
 x 1 execute 
 - 0 no permission 

Changing file permission
# chmod [-R] mode file|directory
where Mode is 
 u user 
 g group 
 o others 
 a all
 + grant 
 - deny

Changing file ownership
# chown [–R] user file|directory
# chown [-R] user:group file|directory
# chgrp [–R] group file|directory

SUID and SGID Executables
Set on an executable file cause it to run under the user/group security context of file owner/group

SGID Directories
File created in directory with SGID bit set, it belongs to the same group as the directory

Sticky Bit
Only owner can delete the file
# chmod o+t directory
T appears if directory execute permission for others is off

 Octal Mode Number Description
 1000 Sets the sticky bit
 2000  Sets the setgid bit
 4000 Sets the setuid bit

Linux Read mode permissions
  • Read access on a file allows you to view file 
  • Read access on a directory allows you to view directory contents with ls command 
Write mode permissions
  • Write access on a file allows you to write to file 
  • Write access on a directory allows you to remove or add new files 
Execute mode permissions
  • Execute access on a file allows to run program or script 
  • Execute access on a directory allows you access file in the directory  
Default File permission
Umask used to withhold permission on file creation
Default User’s umask is 022
File will have 644
Directories will have 755

File Types

 Symbol Meaning  Description 
 - Regular Files like word, text etc
 d Directory File to hold other file types
 b Block Accepts input in blocks [group of byte] e.g. Storage devices
 c Character Accepts input one character [byte] at a time e.g. Serial port
 p Pipe Allows sending info between apps
 s Socket Allows info to be exchanged over network
 l Link Additional pathname to reference

Two types of Links
Hard link share the same inode
Soft link is more of a short cut to the original file

Executables types
1. Binary Files
2. Scripts    #!/usr/bin/bash  Interpreter

Determining file content
# file filename

Report use of specific file or file system
# fuser file|filesystem

Similar to fuser with more info
# lsof file|filesystem

File System Hierarchy

  • The Filesystem Hierarchy Standard (FHS) defines the main directories and their contents in Linux operating systems
  • All files and directories appear under the root directory "/", even if they are stored on different physical devices
  • Single rooted inverted tree like structure
  • Begins at root directory (/)

 Directory Description 
 / Primary hierarchy root and root directory of the entire file system hierarchy
 /home, /root  Home Directories
 /bin, /usr/bin, /usr/local/bin User Executables
 /sbin, /usr/sbin, /usr/local/sbin Executables used by root user
 /etc Configuration files
 /tmp Temporary files 
 /boot Kernel and Boot loaders 
 /var, /srv Server data 
 /proc, /sys System information 
 /dev Devices attached to the system
 /lib, /usr/lib, /usr/local/lib Shared libraries needed to execute binaries 
 /opt Provides storage for large, static application packages
 /media, /mnt Mount points 

Absolute path - Complete road map to file location (/usr/share/doc/HTML/index.html)
Relative path - Specify location relative to your current working directory (index.html)

File System - Swap Space

Swap space in Linux is used when the amount of physical memory (RAM) is full. If the system needs more memory resources and the physical memory is full, inactive pages in memory are moved to the swap space.

Swap space can be a dedicated swap partition (recommended), a swap file, or a combination of swap partitions and swap files

Steps to create swap
  • fdisk device_name - to create a partition
  • mkswap partition – initialize swap partition
  • swapon partition – enable the swap partition
  • swapon –s - to list the swap partition
  • Add a entry in /etc/fstab file to mount after reboot
To create new swap partition
# lvcreate vg0 –n lv2 –L 512M
Initialize new swap
# mkswap /dev/vg0/lv2
Enable swap partition
# swapon –va
Add an entry to fstab
# vi /etc/fstab
/dev/vg0/lv2 swap swap defaults 0 0
To check the swap partition information
# cat /proc/swaps
or 
# swapon -s

To remove swap partition
# swapoff -v /dev/vg0/lv2
# lvremove /dev/vg0/lv2
Remove the fstab entry
# vi /etc/fstab
#/dev/vg0/lv2 swap swap defaults 0 0
To check the swap partition information
# cat /proc/swaps

To create a swap file
# dd if=/dev/zero of=/swapfile bs=1024 count=65536
# mkswap /swapfile
Add an entry to fstab
# vi /etc/fstab
/swapfile swap swap defaults 0 0
# swapon /swapfile
# cat /proc/swaps

To remove a swap file
# swapoff -v /swapfile
# rm /swapfile
# cat /proc/swaps

File System - Inode

Inode
Each object in the file system is represented by an inode. Inode is also know as index number.

Information stored in inode are
File type (executable, block special etc)
Permissions (read, write etc)
Owner
Group
File Size
File access, change and modification time only not creation time
File deletion time
Number of links (soft/hard)
Extended attribute such as append only or no one can delete file including root user (immutability)
Access Control List (ACLs)

# ls -i /etc/passwd
or
# stat /etc/passwd

File System

File System is a format, how information is stored as files and directories

Different Partition Types
  1. ext2   The standard Linux file system 
  2. ext3   The standard Linux file system with journaling added 
  3. vfat   Microsoft's Fat32 file system 
  4. LVM   Logical Volume Manager
  5. Swap Partition  Virtual Memory (Twice size of RAM)
Note
5 or f –extended partition
82 – Linux swap
83 – Linux
8e – Linux LVM

Steps to add new filesystems
Identify device -> partition device -> make filesytem -> label filesytem -> entry in fstabl -> mount it

Commands for managing partitions
# fdisk
To save partition table
# partprobe
To create filesytem
# mkfs.ext2 
# mkfs.ext3 
an alternate way to refer to devices (e.g. e2label /dev/hda3 dbdisk)
# e2label
Mount the filesystem
# mount LABEL=dbdisk /mnt/data
To set filesytem paramenters like acl, reserved blocks, fsck frequency 
# tune2fs
check and repair filesystem
# fsck filesystem

Steps to create filesystem
  • fdisk device_name - to create a partition
  • mke2fs –j partition – to create a filesystem
  • fsck –f partition – to verify any errors in filesystem
  • mount device_name mount_point – mount the created filesystem to a directory
  • Add a entry in /etc/fstab file to mount after reboot

fstab
/etc/fstab contains all mount points and contains
Device, mount_point, fs_type, options(ACL, quota), dump_freq, fsck_order

Mount
mount –a – mount all filesystem
mount –t vfstype
options like rw, suid, exec, acl

Unmount
umount [options] device|mount_point
remount option to change mounted filesytem options like readonly
fuser file|filesystem displays pid of process using filesystem

Label a Linux Partition
Display current label
# e2label /dev/sda1

Display the labels of all mounted filesystems
# mount -l

Set a new label
# e2label /dev/sdb2 usbstroage
or
# tune2fs -L usbstroage /dev/sdb2

Network

Primary Network Configuration files

/etc/hosts — The main purpose of this file is to resolve hostnames that cannot be resolved any other way. It can also be used to resolve hostnames on small networks with no DNS Server
/etc/resolv.conf — This file specifies the IP addresses of DNS servers and the search domain
/etc/sysconfig/network — Specifies routing and host information for all network interfaces
/etc/sysconfig/network-scripts/ifcfg- — For each network interface, there is a corresponding interface configuration script. Each of these files provide information specific to a particular network interface

Ethernet Interfaces
Linux network interface names start with ethX. First Ethernet network interface name is eth0, second is eth1 and so on

Loopback Interface
ifcfg-lo — A local loopback interface is often used in testing, as well as being used in a
variety of applications that require an IP address pointing back to the same system. Any data
sent to the loopback device is immediately returned to the host's network layer

Alias
Alias interface configuration files, which are used to bind multiple addresses to a single interface, use the ifcfg-: naming scheme
ifcfg-eth0:0 file could be configured to specify DEVICE=eth0:0
Alias interfaces do not support DHCP

Network Administration Tool
# system-config-network
or
# setup

To list or display information about all network interface
# ifconfig -a

To assign ip address to a interface temporarily 
# ifconfig eth0 192.168.1.1 netmask 255.255.255.0 up

To bring up ethX, where X can be 0,1,2....
# ifup ethX

To bring down ethX
# ifdown ethX

To restart network Services
# service network restart

To assigns hostname to a machine
# hostname name

Using DHCP to Obtain an IP Address
# dhcpcd eth0

Package Management

Yellow Dog Update Manager (YUM)
It’s a repository and stored some rpm
Repository info stored in /etc/yum.repos.d/rhel.debuginfo.repo

Yum configuration file
# less /etc/yum.conf

Install a new package called foo
# yum install foo

 To update all packages
# yum update

To update a single package called foo
# yum update foo

To remove a package called foo
# yum remove foo

To list all installed packages
# yum list installed

Display information on a package called foo
# yum info foo

To display list of packages for which updates are available
# yum list updates
or
# yum check-update

To find any packages matching a string in  the  description,  summary, packager and package name fields of an rpm
# yum search foo

Create private repository
createrepo –v /package/directory
repomd.xml – contain timestamp and checksum for other 3files
primary.xml.gz – contains list of rpm and dependency in repo
filelists.xml.gz – contains list of files in rpm
other.xml.gz – additional info
comps.xml – info about package group

Configuring repository
/etc/yum.reps.d
[repo-name]
name=description
baseurl=http://server.com/path
enabled=1
gpgcheck=1

Cron

crontab  cron table (Time Based Scheduler)

Cron is Linux daemon to execute scheduled commands. It is also known as the clock daemon that executes commands at specified dates and times according to instructions in a file.

Generally, crontab uses a daemon, crond, which runs constantly in the background and checks once a minute to see if any of the scheduled jobs need to be executed. If so, it executes them. These jobs are generally referred to as cron jobs.

Cron is controlled by a set of files called "crontabs". There is the master file in /etc/crontab. 
Cron runs every minute

File Location
Contains cron entry for each user
# ls -l /var/spool/cron/
Software package can install cron entry for them
# ls -l /etc/cron.d
Used for system maintenance task
# ls -l /etc/crontab

Cron file contains
 Min Hour  Day  Month Weekly User  Command
 0-59 0-23  0-31 1-12 0-6 Username Command

*   -  match everything
Single Integer  -  Match exactly
Two integer separated by comma  - Range of value
Comma separated series of integer  - matching any listed value

crontab filename   Install cronjob
crontab –e    view in editor
crontab –l    list the content
crontab –r    remove the entry

Restrict access by /etc/cron.allow and /etc/cron.deny
If both file exist, deny is ignored

/etc/cron.d contain system crontab
/etc/cron.hourly
/etc/cron.daily
/etc/cron.weekly
/etc/cron.monthly

Daily corn jobs
tmpwatch - deletes all files from tmp
logrotate - (config file in /etc/logrotate.conf) messages rotated 
logwatch - (config file in /etc/log.d/conf/logwatch.conf) monitor log files

Linux / UNIX Restrict at / cron Usage To Authorized Users

First, delete both /etc/cron.deny and /etc/at.deny files
/etc/cron.allow - Put users who are allowed to use cron
/etc/at.allow - Put users who are allowed to use at

To start the cron service
# /etc/init.d/crond start

To stop the cron service
# /etc/init.d/crond stop

To check status of cron service
# /etc/init.d/crond restart

A text based GUI tool called ntsysv to enable crond service:
# ntsysv

Running job at statup (boot)
@reboot /path/to/command

Syslog

Syslog is the logging system for UNIX and Linux
Logging Polices
1. Reset log files at periodic intervals (grow to fixed size and then reset to zero size)
2. Rotate log files, keeping date for a fixed time (e.g. log.1, log.2)
3. Compress and Archive log to Tape

syslog config file (/etc/syslog.conf)
/var/log/file default permission should be 
chmod 600
klogd - Kernel ongoing logging
initlog capture O/P of startup command and submit to syslog
Syslog Architecture
syslogd writes its process id to 
/var/run/syslog.pid
1. syslogd Logging Daemon
2. openlog Library Routine that submit message to syslogd
3. logger User-level command that submit log entry from shell

Log facility and level are configured in /etc/initlog.conf
selector actions
selector has
facility  - program that is sending the log messages
level – messages severity level
facility.level action
mail.info /var/log/maillog
facilty names include
auth - security and authorization related commands
daemon - system daemons
kern - the kernel
mail - sendmail and other mail related softwares
syslog - syslogd internel messges
user - user process

syslog severity levels
emerg - panic situations
alert - urgent situations
crit - critical conditions
err - error conditions
warning - warning messages
notice - things need investigation
info - information messages
debug - debugging only

logger command is used for submitting log entries from shell script
$
logger –p local5.warning “test msg”
And add [local5.warning /tmp/evi.log] in syslogd’s config file

Using syslog from programs
use Sys::Syslog
openlog Routine to initialize logging
syslog Send a message to syslogd which log
closelog closes the logging channel

Saturday, October 24, 2009

Installing Word Press

Word Press

Requirements:

PHP , MySql , Apache


1.Download the zip from http://wordpress.org/
2.Unzip the downloaded file .
3.copy the file into htdocs
4.Create a database for WordPress on your web server and give all privileges for accessing and modifying it.
5.Rename the wp-config-sample.php file to wp-config.php.
6.Edit wp-config-sample.php to change the file is as follows: DB_NAME , DB_USER , DB_PASSWORD , DB_HOST (99% chance you won't need to change this value)
7.Save the file.
8.Run the WordPress installation script by accessing wp-admin/install.php in browser.
9.WordPress in its own subdirectory called blog, for example, you should visit: http://localhost/blog/wp-admin/install.php


Reference

http://codex.wordpress.org/Installing_WordPress#Famous_5-Minute_Install

Create a new Multiple user accounts in Windows XP

Adding a new Window Xp User Accounts
The administrator or a user with administrator rights can create additional user accounts.
1.Click the Start button and click Control Panel.
2.In the Control Panel window, click User Accounts.
3.Under Pick a task, click Create a new account.
4.Under Name the new account, type the name of the new user and click Next.
5.Under Pick an account type, click one of the following options:
Computer administrator — You can change all computer settings.
Limited — You can change only your own personal settings, such as your password. You cannot install programs or use the Internet.
6. Click Create Account.
Adding a new Window Xp User Accounts using Dos Prompt.

To create a new account you have to type as follows :
net user USERNAME PASSWORD /ADD
Ex: net user sampleuser welcome /add

To delete the account type as follows :
net user USERNAME /del
Ex: net user sampleuser welcome /del

To get Admin rights type as follows :
net localgroup administrators username /add

The complete command is
[username [password | *] [options]] [/DOMAIN]
username {password | *} /ADD [options] [/DOMAIN]
username [/DELETE] [/DOMAIN]

To Create Folder for user :
mkdir username

To Create Folder for Multiple users :
mkdir username1 username2 username3 ...............usernameN

Save the Multiple user file as .bat and in Dos prompt
Ex :Sampleuserfile.bat
following commands are in Sampleuserfile.bat

net user sampleuser1 welcome /add
net user sampleuser2 welcome /add
net user sampleuser3 welcome /add
........................................
net user sampleuserN welcome /add

If we run Sampleuser.bat in Command Prompt or Double Click the Sampleuser.Bat file then following user accounts are created.
Sampleuser1
Sampleuser2
Sampleuser3
....................
SampleuserN
Ex : Sampleuserfolder.bat
username1
username2
..................
usernameN

When you share a folder from your Xdrive, you can control how others access the contents of that folder by setting folder permissions. When you allow others to upload new files to a folder, you can set a quota to limit the amount of space available to the users you are sharing with.

Tuesday, October 6, 2009

Installing MediaWiki

Required software:
Web Server such as Apache or IIS
PHP version 5.0 or Later, and
Database Server MySQL or PostgreSql
sudo apt-get install httpd
sudo apt-get install mysql-server
sudo apt get install php5
sudo apt-get install php5-mysql
sudo apt-get install php5-cli
If you want to use the GD library (instead of ImageMagick for image resizing)
sudo apt-get install libgd2-xpm
sudo apt-get install libgd2-xpm-dev
sudo apt-get install php5-gd
Configure MySQL
mysqladmin -u root password ""
history -c
Note: Remember this user (root) and password because you will need them when you configure
MediaWiki.
Configure PHP
Edit your php configuration file.
sudo nano /etc/php.ini
Maximum Upload Filesize
Assuming that various files are going to be uploaded to the Wiki as content, the limit on the
maximum size of an upload has to be adjusted. About one­half way down is the File Uploads
section. Change:
upload_max_filesize = 2M
to at least 8M. You may have to adjust this again in the future.
upload_max_filesize = 8M
Memory Limit
Some PHP scripts require a lot of memory to run. To increase the maximum amount of memory a
script can use, page down to about 21%, and change the following entry, if found, from
memory_limit = 8M
to
memory_limit = 12M
Extensions
PHP MySQL support has to be enabled. Page down a bit further (about 48%) and make sure the
following line is uncommented:
extension=mysql.so
If you use the GD graphics library to do image resizing (instead of ImageMagick), also uncomment:
extension=gd.so
Save and exit out of the editor and restart Apache:
sudo /etc/init.d/httpd restart
MediaWiki
Type the following commands (replace 1.13.3 with the version to download)...
cd /var/www/
we need to extract the files...
sudo tar vxfz mediawiki-1.13.3.tar.gz
rename the extracted directory name to wiki
sudo mv mediawiki-1.13.3 wiki
In order to configure the wiki you have to make the config subdirectory writable by the web server.
cd /var/www/wiki
sudo chmod a+w config
Configure MediaWiki
Navigate your browser to http://localhost/wiki and continue with the installation.
Fill out the configuration form and continue.

Google Apps set up process

1. Browse the below link to Goto the Google Apps Page.

http://www.google.com/apps/intl/en/group/index.html


2. Click the "Get Started" button on the right side of the page for Standard Edition.
3. Here We have to select "I want to use an existing domain name" tab.

4. On that tab, it shows the below two options.

a. Administrator: I own or control this domain

b. End-user: I am a member of this domain

5. Here we should select the below option.

"Administrator: I own or control this domain"

6. Then Enter your Domain Name and Click the "Get Started" Button.

(eg) your_domain (what ever you need)

7. After select the domain it ask some information about our's.

8. Fill all the Manditory fields and then click "continue" button.

9. Here we Should create a Administrator account for that Domain.

10. And then Click "I accept. Continue with set up >>" button.


11. Here we log into our Dashboard then click the following link to activate our Google Apps services.

Verify domain ownership

12. In Verify ownership page select "Change the CNAME Record" from the Dropdown list. After select it views some unique string.

13. Copy the unique string to create a new CNAME record for your domain.

unique string eg:- google4e9d0b25319a7bab

And then click "Verify" button.

14. Now do the following in godaddy account.

Godaddy Settings:-

1. Log in to your account at http://www.godaddy.com.
2. To Update the MX records for basic email services using the below link https://www.godaddy.com/gdshop/google/gmail_login.asp and provide your domain name.
3. On the godaddy home page, Click the "Domains" tab and select "My Domain" Names. You'll be directed to the “Manage Domains page”.
4. Click the domain that use with Google Apps.
5. After you select that Domain it views the specific Domain Details.
6. In this page click the Total DNS Control Link.
7. Second tab refers CNAME(Aliases) , Click the Add New CNAME Record button
8. Under the CNAME tab enter the Alias name as CNAME Unique string and Host Name as google.com then Click Ok.
9.
10. On the Total DNS Control Panel, expand the MX (Mail Exchange) section by clicking on the + icon next to the MX (Exchange) list item. A list of MX entries will appear.
11. Clear all existing MX Records by clicking on the X Icon under the Actions section. Note: Make sure that there are no entries left in the MX (Mail Exchange) section.
12. Once you've deleted all existing records, click Add New MX Record. The MX (Mail Exchangers) Record Wizard will appear.
13. For each MX Record, enter information according to the data in the table below:


PriorityValue HostName Goes To Address
(Mail Server) TTLValue
1 @ .s9a1.psmtp.com. 1 Hour
2 @ .s9a2.psmtp.com. 1 Hour
3 @ .s9b1.psmtp.com. 1 Hour
4 @ .s9b2.psmtp.com. 1 Hour

* For the Select the Priority Value drop-down menu, enter the priority value (Choose Custom).
* For Enter a Host Name, leave the default setting to @.
* For the Select TTL Value drop-down menu, enter 1 Hour. This will appear as 3600 seconds within the DNS system.
* For Enter Goes To Address enter the Gmail server name.
* Click OK. The interface will show a Pending… status in the Actions section after you've made changes to your records

15. Enter the domain name and then click confirm.
16. Once above steps done get back to same page of step 13 .


17. On the "Set up email delivery" page Click the "I have completed these steps" button.

Use this direct link to update the MX records in godaddy automatically while setting up Google Apps

https://www.godaddy.com/gdshop/google/gmail_login.asp.

configuring postgres for network connections

http://www.cyberciti.biz/tips/postgres-allow-remote-access-tcp-connection.html

Glassfish Server Setting


Step : 1

/domains/domain1/lib/ext/<MySql connector>

Step : 2(Project specific)

/domains/domain1/config/domain.xml

-----------------------------------------------------------------------------------------------------------
 

" object-type="user" pool-name="pool name>"/>

   attempts="0" connection-creation-retry-interval-in-seconds="10" connection-leak-reclaim="false" connection-leak-timeout-in-seconds="0" connection-validation-method="auto-commit" datasource-classname="com.mysql.jdbc.jdbc2.optional.MysqlConnectionPoolDataSource" fail-all-connections="false" idle-timeout-in-seconds="300" is-connection-validation-required="false" is-isolation-level-guaranteed="false" lazy-connection-association="false" lazy-connection-enlistment="false" match-connections="false" max-connection-usage-count="0" max-pool-size="32" max-wait-time-in-millis="60000" name="" non-transactional-connections="false" pool-resize-quantity="2" res-type="javax.sql.ConnectionPoolDataSource" statement-timeout-in-seconds="-1" steady-pool-size="8" validate-atmost-once-period-in-seconds="0" wrap-jdbc-objects="false">

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

      "/>

     

     

     

     

     

     

     

     

     

     

      "/>

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

      "/>

     

     

     

     

     

     

     

      "/>

     

     

     

     

     

     

     

     

     

     

      :/"/>

   



-------------------------------------------------------------------------------------------------------------------


Step : 3(Project specific)

/domains/domain1/config/login.conf

------------------------------------------------------------------

{

      com.sirahu.security.UserLoginModule required

      URL = "jdbc:mysql://:/"

        DRIVER_CLASS = "com.mysql.jdbc.Driver"

        USERID = ""

      PASSWORD=""

      QUERY = "";

    };

-----------------------------------------------------------------

Step : 4(Project specific)

/domains/domain1/config/server.policy





Step : 5

Restart the Glassfish server.


NOTE:

Items marked in Red are variables. Please refer the appendix for those items.


Appendix:

      : Glassfish Directory

                        : specify the project name

   : specify a name to the connection pool

                      : Data base user name

                         : Data base password

                              : Data base instance port no.

                        : Data base instance machine IP

                          : Data base schema name

                   : This is the name specified in the application level for JAAS login

                     : Always use mysql-connector-java-5.0.4-bin.jar