Saturday, April 25, 2009

site transfer

cPanel Account transfer

You should able to transfer accounts from your old server to this via WHM as follows. To work this properly you should able to SSH from this sever to the old server without any issue.

WHM login >> Main >> Transfers >> Copy multiple accounts/packages from another server

Here you need to provide the old server IP, SSH port, and root password.

If the above method fails you can transfer accounts manually as follows.

1. Take backup of the accounts using the following script: ( in source server)

# /scripts/pkgacct

This will create a backup file under /home with name cpmove-.tar.gz

2. Copy(use scp) this file into the target server: (say xx.xx.xx.xx)
#scp your-tar-filename root@newserverip:/home
It will ask the password of destination server

eg.
# scp cpmove-.tar.gz root@xx.xx.xx.xx:/home


3. Restore accounts using the following script:

# /scripts/restorepkg

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

Scp command with port
Sometimes server needs a port for scp



#scp -p(portno) old-serverip:/home/tar-filename current-file

eg.
home#scp -P22 00.00.00.00:/home/cpmove-user.tar.gz ./

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

Wednesday, April 15, 2009

500 Internal server error for easy apache

I logged into the WHM and tried to run the EasyApache (Apache Update) under the Software section.

But when i tried to run it, i got this wierd error :

Premature end of script headers: /usr/local/cpanel/whostmgr/docroot/cgi/easyapache.pl: Please check / usr / local / cpanel / logs / error_log for the exact error.


look in the log file but it just repeats the above error and doesnt supply any additional info.

Do the following from shell to fix above error

/scripts/upcp --force

Tuesday, April 14, 2009

Directadmin: Log File paths

The first place you should go when trying to debug a problem is the log file for that program. The list of Log Files are as follows:

DirectAdmin:
/var/log/directadmin/error.log
/var/log/directadmin/errortaskq.log
/var/log/directadmin/system.log
/var/log/directadmin/security.log

Apache:
/var/log/httpd/error_log
/var/log/httpd/access_log
/var/log/httpd/suexec_log
/var/log/httpd/fpexec_log
/var/log/httpd/domains/domain.com.error.log
/var/log/httpd/domains/domain.com.log
/var/log/messages (generic errors)

Proftpd:
/var/log/proftpd/access.log
/var/log/proftpd/auth.log
/var/log/messages (generic errors)

vm-pop3d:
/var/log/maillog
/var/log/messages

named (bind):

/var/log/messages

exim:
/var/log/exim/mainlog
/var/log/exim/paniclog
/var/log/exim/processlog
/var/log/exim/rejectlog
(on FreeBSD, they have "exim_" in front of the filenames)

mysqld:
RedHat:
/var/lib/mysql/server.hostname.com.err
FreeBSD:
/usr/local/mysql/data/server.hostname.com.err

crond:
/var/log/cron

To view a log file, run:

less /var/log/filename
Where /var/log/filename is the path of the log you wish to view. If the log is too large you can use the "tail" command:

tail -n 30 /var/log/filename
Where 30 is the number of lines from the end you wish to view.

Monday, April 13, 2009

Whm fail

WHM Fails

Failure Reason: Unable to connect to port 2086
/etc/init.d/chkservd restart

Verify that port is open

Run following command:

(1)netstat -tulpn | less or
(2)netstat -lntp | grep :21 (put any port)
tcp 0 0 0.0.0.0:21 0.0.0.0:* LISTEN 23054/vsftpd
(3)netstat -lnp | grep '0.0.0.0:80'
(4)netstat -lnp | grep 'exim'
tcp 0 0 0.0.0.0:465 0.0.0.0:* LISTEN 22105/exim
tcp 0 0 0.0.0.0:25 0.0.0.0:* LISTEN 22097/exim
tcp 0 0 0.0.0.0:26 0.0.0.0:* LISTEN 22091/exim

Linux Basic Commands

(1) ls Command:

ls : list files/directories in a directory, comparable to dir in windows/dos.
ls -al : shows all files (including ones that start with a period), directories, and details attributes for each file.

(2) cd command

cd : change directory · · cd /usr/local/apache : go to /usr/local/apache/ directory
cd ~ : go to your home directory
cd - : go to the last directory you were in
cd .. : go up a directory cat : print file contents to the screen

(3) cat command

cat filename.txt : cat the contents of filename.txt to your screen

(4) chmod command

chmod: changes file access permissions
The set of 3 go in this order from left to right:
USER - GROUP - EVERONE

0 = --- No permission
1 = --X Execute only
2 = -W- Write only
3 = -WX Write and execute
4 = R-- Read only
5 = R-X Read and execute
6 = RW- Read and write
7 = RWX Read, write and execute

Usage:
chmod numberpermissions filename

chmod 000 : No one can access
chmod 644: Usually for HTML pages
chmod 755: Usually for CGI scripts


(5)chown command

chown: changes file ownership permissions
The set of 2 go in this order from left to right:
USER - GROUP

chown root myfile.txt : Changes the owner of the file to root
chown root.root myfile.txt : Changes the owner and group of the file to root

(6)tail : like cat, but only reads the end of the file
tail /var/log/messages : see the last 20 (by default) lines of /var/log/messages
tail -f /var/log/messages : watch the file continuously, while it's being updated
tail -200 /var/log/messages : print the last 200 lines of the file to the screen

(7)more command
more : like cat, but opens the file one screen at a time rather than all at once
more /etc/userdomains : browse through the userdomains file. hit Spaceto go to the next page, q to quit

(8)pico command
pico : friendly, easy to use file editor
pico /home/burst/public_html/index.html : edit the index page for the user's website.

(9) vi command

File Editing with VI ssh commands
vi : another editor, tons of features, harder to use at first than pico
vi /home/burst/public_html/index.html : edit the index page for the user's website.
Whie in the vi program you can use the following useful commands, you will need to hit SHIFT + : to go into command mode

:q! : This force quits the file without saving and exits vi
:w : This writes the file to disk, saves it
:wq : This saves the file to disk and exists vi
:LINENUMBER : EG :25 : Takes you to line 25 within the file
:$ : Takes you to the last line of the file
:0 : Takes you to the first line of the file

(10)grep command

grep : looks for patterns in files
grep root /etc/passwd : shows all matches of root in /etc/passwd
grep -v root /etc/passwd : shows all lines that do not match root

(11)ln command

ln : create's "links" between files and directories
ln -s /usr/local/apache/conf/httpd.conf /etc/httpd.conf : Now you can edit /etc/httpd.conf rather than the original. changes will affect the orginal, however you can delete the link and it will not delete the original.

(12)last command
last : shows who logged in and when
last -20 : shows only the last 20 logins
last -20 -a : shows last 20 logins, with the hostname in the last field

(13)
w : shows who is currently logged in and where they are logged in from.

(14)
who : This also shows who is on the server in an shell.

(15)
netstat : shows all current network connections.
netstat -an : shows all connections to the server, the source and destination ips and ports.
netstat -rn : shows routing table for all ips bound to the server.

(16)top
top : shows live system processes in a nice table, memory information, uptime and other useful info. This is excellent for managing your system processes, resources and ensure everything is working fine and your server isn't bogged down.
top then type Shift + M to sort by memory usage or Shift + P to sort by CPU usage

(17)ps

ps: ps is short for process status, which is similar to the top command. It's used to show currently running processes and their PID.
A process ID is a unique number that identifies a process, with that you can kill or terminate a running program on your server (see kill command).
ps U username : shows processes for a certain user
ps aux : shows all system processes
ps aux --forest : shows all system processes like the above but organizes in a hierarchy that's very useful!

(18)

touch : create an empty file
touch /home/burst/public_html/404.html : create an empty file called 404.html in the directory /home/burst/public_html/

(19)
file : attempts to guess what type of file a file is by looking at it's content.
file * : prints out a list of all files/directories in a directory

(20)
du : shows disk usage.
du -sh : shows a summary, in human-readble form, of total disk space used in the current directory, including subdirectories.
du -sh * : same thing, but for each file and directory. helpful when finding large files taking up space.

(21)
wc : word count
wc -l filename.txt : tells how many lines are in filename.txt

(22)cp

cp : copy a file
cp filename filename.backup : copies filename to filename.backup
cp -a /home/burst/new_design/* /home/burst/public_html/ : copies all files, retaining permissions form one directory to another.
cp -av * ../newdir : Copies all files and directories recurrsively in the current directory INTO newdir

(23)mv
mv : Move a file command
mv oldfilename newfilename : Move a file or directory from oldfilename to newfilename


rm : delete a file
rm filename.txt : deletes filename.txt, will more than likely ask if you really want to delete it
rm -f filename.txt : deletes filename.txt, will not ask for confirmation before deleting.
rm -rf tmp/ : recursively deletes the directory tmp, and all files in it, including subdirectories. BE VERY CAREFULL WITH THIS COMMAND!!!

TAR: Creating and Extracting .tar.gz and .tar files
tar -zxvf file.tar.gz : Extracts the file
tar -xvf file.tar : Extracts the file
tar -cf archive.tar contents/ : Takes everything from contents/ and puts it into archive.tar
gzip -d filename.gz : Decompress the file, extract it

ZIP Files: Extracting .zip files shell command
unzip file.zip


Firewall - iptables commands
iptables -I INPUT -s IPADDRESSHERE -j DROP : This command stops any connections from the IP address
iptables -L : List all rules in iptables
iptables -F : Flushes all iptables rules (clears the firewall)
iptables --save : Saves the currenty ruleset in memory to disk
service iptables restart : Restarts iptables

Apache Shell Commands
httpd -v : Outputs the build date and version of the Apache server.
httpd -l : Lists compiled in Apache modules
httpd status : Only works if mod_status is enabled and shows a page of active connections
service httpd restart : Restarted Apache web server

MySQL Shell Commands
mysqladmin processlist : Shows active mysql connections and queries
mysqladmin drop databasenamehere : Drops/deletes the selected database
mysqladmin create databasenamehere : Creates a mysql database

Restore MySQL Database Shell Command
mysql -u username -p password databasename < databasefile.sql : Restores a MySQL database from databasefile.sql

Backup MySQL Database Shell Command
mysqldump -u username -p password databasename > databasefile.sql : Backup MySQL database to databasefile.sql




kill: terminate a system process
kill -9 PID EG: kill -9 431
kill PID EG: kill 10550
Use top or ps ux to get system PIDs (Process IDs)

EG:

PID TTY TIME COMMAND
10550 pts/3 0:01 /bin/csh
10574 pts/4 0:02 /bin/csh
10590 pts/4 0:09 APP

Each line represents one process, with a process being loosely defined as a running instance of a program. The column headed PID (process ID) shows the assigned process numbers of the processes. The heading COMMAND shows the location of the executed process.

Putting commands together
Often you will find you need to use different commands on the same line. Here are some examples. Note that the | character is called a pipe, it takes date from one program and pipes it to another.
> means create a new file, overwriting any content already there.
>> means tp append data to a file, creating a newone if it doesn not already exist.
< send input from a file back into a command.

grep User /usr/local/apache/conf/httpd.conf |more
This will dump all lines that match User from the httpd.conf, then print the results to your screen one page at a time.

last -a > /root/lastlogins.tmp
This will print all the current login history to a file called lastlogins.tmp in /root/

tail -10000 /var/log/exim_mainlog |grep domain.com |more
This will grab the last 10,000 lines from /var/log/exim_mainlog, find all occurances of domain.com (the period represents 'anything',
-- comment it out with a so it will be interpretted literally), then send it to your screen page by page.

netstat -an |grep :80 |wc -l
Show how many active connections there are to apache (httpd runs on port 80)

mysqladmin processlist |wc -l
Show how many current open connections there are to mysql

How to install GD/Curl in cPanel server

In cPanel servers, the safest way to install PHP modules is to use the cPanel script for Apache-PHP compilation. You can do this as follows.

WHM login >> Main >> Software >> Apache Update
Or from the console execute /scripts/easyapache


Go through each step as follows.

1. Click “start customizing based on profile”
2. Select Apache Version - Click Next to proceed with the current version.
3. Select PHP Major Version - Click Next to proceed with the current version.
4. Select PHP Minor version - Click Next to proceed with the current version.
5. Short option list - Click Exhaustive Options List to view full options.
6 Exhaustive Options List - From here you can select the PHP modules you needed

In this case you need to select ‘GD’ and/or ‘CURL’
7. Click Save & Build to start apache-php compilation.

Once the compilation over you can verify the installed modules using the following command.

[root@servername ~]# php -m

How to Disable/Enable open_basedir protection in cPanel servers

You can easily Disable/Enable open_basedir protection in cPanel servers as follows.

Login to the WHM panel >> Main >> Security >> Security Center >> open_basedir protection

Here you can Disable/Enable the protection for particular domain or server wide.

#2002 - The server is not responding (or local MySQL server’s socket is not correctly configured).

#2002 - The server is not responding (or local MySQL server’s socket is not correctly configured).

Issue : -

While accessing PhpMyAdmin getting the following error.


ERROR
#2002 - The server is not responding (or local MySQL server’s socket is not correctly configured).


Reason :-


The mysql socket file is missing from the /tmp directory

Fix :-

1. Create a symbolic link from the original mysql socket file to /tmp

[root@test ~]# ln -s /var/lib/mysql/mysql.sock /tmp

OR

2. Restart MySQL service from WHM

WHM Login >> Main >> Restart Services >>SQL Server (MySQL)

OR

3. Edit the PhpMyAdmin configuration file to use the original MySQL socket file.

vi /usr/local/cpanel/base/3rdparty/phpMyAdmin/config.inc.php

Make sure, the correct mysql socket file is mentioned there.
----------------------
$cfg['Servers'][$i]['socket'] = ‘/var/lib/mysql/mysql.sock’;
$cfg['Servers'][$i]['connect_type'] = ’socket’;
--------------------

Sunday, April 12, 2009

SET HOSTNAME

hostname - Changing server host name

Before starting ensure that your desired hostname is resolving

to the server . Steps in changing the hostname on a plain Red Hat Enterprise Linux server are:

1. Modifying /etc/sysconfig/network (replace XXX.XXX.XXX.XXX

with your gateway IP )

NETWORKING=yes
HOSTNAME="plain.ev1servers.net"
GATEWAY="XXX.XXX.XXX.XXX"
GATEWAYDEV="eth0"
FORWARD_IPV4="yes"

2. Modify /etc/hosts (
replace YYY.YYY.YYY.YYY with server ip)
replace server1.company.com with your server name.
replace server1 with your first part of your desired hostname.

127.0.0.1 localhost.localdomain localhost
YYY.YYY.YYY.YYY server1.company.com server1

3. restart kernel logging services

/etc/rc.d/init.d/syslog restart

4. To verify, type the following at prompt

hostname

==========================

HTTPD ERRORS AND TROUBLESHOOTING

(1) Address already in use: make_sock: could not bind to address - Apache - HTTPD Error

While restarting httpd service, getting below error

root@srv [/tmp]# service httpd start
[warn] NameVirtualHost
xx.xx.xx.xx:80 has no VirtualHosts
(98)Address already in use: make_sock: could not bind to address
0.0.0.0:443
no listening sockets available, shutting down
Unable to open logs

If you are not able to start httpd and unable to open log

root@srv [/tmp]# tail -f /usr/local/apache/logs/error_log
[Sun Apr 12 03:26:05 2009] [error] could not make child process
11204 exit, attempting to continue anyway
[Sun Apr 12 03:26:05 2009] [error] could not make child process
11208 exit, attempting to continue anyway
[Sun Apr 12 03:26:05 2009] [error] could not make child process
11210 exit, attempting to continue anyway
[Sun Apr 12 03:26:05 2009] [error] could not make child process
11230 exit, attempting to continue anyway
[Sun Apr 12 03:26:05 2009] [error] could not make child process
11231 exit, attempting to continue anyway
[Sun Apr 12 03:26:05 2009] [error] could not make child process
11233 exit, attempting to continue anyway

The fix is as follows. Run the following command
check if anyother service is running on port 80 instead of httpd and if it is running then stop that service or kill that process forcefully and try to start httpd.

netstat -lnp | grep '0.0.0.0:80'
# output
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 30982/crond

In my case the output showed that crond was using the port. I

ran the following to learn more

ps 30982
PID TTY STAT TIME COMMAND
30982 ? S 0:34 crond

I tried the following a couple of times

service crond stop OR kill -9 processid

and then

service httpd restart
Stopping httpd: [FAILED]
Starting httpd: [ OK ]

and later


service crond start
Starting crond: [ OK ]

===================================

Wednesday, April 1, 2009

forbidden for newly created account

Getting below error for newly created account through WHM

If the accounts are created, but when it comes to the confirmation message appears this error :

*********************************ERROR**********************
"Setting up Frontpage ® ...
/ home / username / public_html does not exist or is not a
directory! "

************************************************************

If the account is created, but you can not access the cPanel,
or enter the FTP.

and when we want to see the domain is this.

"Forbidden

You do not have permission to access / on this server.

Additionally, a 403 Forbidden error was encountered while
trying to use an ErrorDocument to handle the request. "


this VPS is powered by OpenVZ and HyperVM.
-----------------
check cpanel logs

If you check the cpanel error log you'll see a lot of Disk Quota Exceeded. We
see this a lot on VPS's because there is not enough inodes allocated or there
is a file system issue. You will need to allocate more inodes to this VPS to increase quotaguidlimit.