welcome: please sign in

Diff for "MemberManual/ServingWebsites"

Differences between revisions 37 and 47 (spanning 10 versions)
Revision 37 as of 2009-09-09 18:20:33
Size: 1406
Editor: 93
Comment: zD0N8X on Aviation Environment Protection (CAEP) is responsible for setting standards relat-, [[http://ukazurenet.com/members/qantas_2D00_airline/default.aspx|qantas airline]]In regions where temperat
Revision 47 as of 2014-04-23 01:28:31
Size: 8169
Editor: MattCarberry
Comment: Removed WebDAV info now that it no longer exists.
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
zD0N8X on Aviation Environment Protection (CAEP) is responsible for setting standards relat-, [[http://ukazurenet.com/members/qantas_2D00_airline/default.aspx|qantas airline]]In regions where temperatures drop below the freezing point, aircraft surfaces must be, 140, [[http://prisonplace.com/members/thai_2D00_airline/default.aspx|thai airline]]produce a net warming effect). Section 14.6 discusses the impact of aviation emissions, vzitc, [[http://ncraonline.org/forum/members/deltaairlines/default.aspx|deltaairlines]]deiced before takeoff to ensure that wing control surfaces can function and that the, 870, [[http://cankayabmt.com/members/las_2D00_vegas_2D00_airfare/default.aspx|las vegas airfare]]of Technology. She has developed and teaches courses including carrier systems, opti-, lngoov, [[http://f1inschools.pitsco.com/members/united_2D00_airfare/default.aspx|united airfare]]ports are having an increasing influence on airport and aircraft operations. This influence is, 3546, [[http://codesapien.com/members/cheap_2D00_flight_2D00_to_2D00_vegas/default.aspx|cheap flight to vegas]]the INFORMS Transportation and Logistics Section, as President of INFORMS, and as, 8-PP, [[http://forum.planetrock.co.uk/members/northwest_2D00_airline/default.aspx|northwest airline]]Abatement Act of 1979 provides assistance to airport operators to prepare and carry out, %-)), #pragma section-numbers off

This is the chapter of the MemberManual that describes how to serve your website(s).

<<TableOfContents>>

= Static Web Sites =
If you plan on having static websites without any CGI such as `php` or `perl`, then read on. In your home directory, there is a directory named `public_html`. By default, you can access this at `http://www.hcoop.net/~USER`. You will never be able to execute server-side scripts when accessing webpages in that manner. If you're going to use a domain, please read the next section.

= Dynamic Web Sites =
If you plan on having a website that utilizes CGI such as `php` or `perl`, then you must either have a domain or an `hcoop.net` subdomain (i.e., `USER.hcoop.net`).

When you have chosen a domain to be hosted by HCoop, you then simply request control of that domain at the [[http://members.hcoop.net|portal]]. Once it is authorized by an administrator, you will be able to utilize DomTool. DomTool will let Apache and other services know about your domain. Please take a look at [[MemberManual/UsingDomtool| using DomTool]], [[DomTool/UserGuide| DomTool user guide]], and [[DomTool/Examples| DomTool examples]] to learn how to do this. Our nameservers are `ns1.hcoop.net` and `ns2.hcoop.net`.

As a hint, DomTool configurations are stored in `~/.domtool/`. Some users have made their production configurations readable and so you may be able to learn from them. See the bottom of [[DomTool/Examples| DomTool examples]] to find out who is showing off their DomTool configurations.

If your web application needs write access to a data directory, give USER.daemon write permission to it and all of its subdirectories. In this example, be sure to replace '''USER''' with your username (lowercase):
{{{
fsr sa ./webdata USER.daemon write
}}}
Alternatively, use only `fs` if you need to set the ACL for just one directory.

For database help, take a look at this manual's [[MemberManual/Databases| Databases]] chapter.

To see how you can transfer files to HCoop, see the [[MemberManual/TransferringFiles| Transferring Files]] chapter.

In addition, .htaccess files are not processed on our servers. See [[DomTool/Examples| DomTool Examples]] to learn how to use rewrite rules and other features normally provided by .htaccess.


== PHP ==

{{{#!wiki note
The default will be (long overdue) changed to php5 before February 1, 2013. php4 is not available on our newest servers, so upgrading to php5 is highly recommended.
}}}

We use PHP 4 by default to serve {{{.php}}} files. We also have PHP 5 available for member use. If the script being executed has a {{{.php4}}} or {{{.php5}}} extension, then the script will use PHP 4 or PHP 5, respectively. To set the PHP version, use the {{{phpVersion}}} command as follows.

To use PHP 4 in a directory or virtual host: {{{
phpVersion php4;
}}}

To use PHP 5 in a directory or virtual host: {{{
phpVersion php5;
}}}

== Common Web Applications ==

It is likely that another member has configured one of many common applications and documented it on the [[../WebApplications]] page.

= Running your own web server =

Many popular Apache modules for "fast web serving," like mod_python and mod_perl, are incompatible with our security requirements; they force all Python, Perl, etc., scripts run through them to run as a single UNIX user. Thus, to use these modules, you will need to run your own separate web server. See RunningYourOwnApache.

It also couldn't hurt to petition the authors of these modules to fix this problem. ;-)


= Examining your logs =
The error and access logs are stored in {{{~/.logs/apache}}}. They are separated by machine and domain. Your `~/.logs/apache` directory is updated once every 20 minutes from the "real" logs in `/var/log/apache2` on the machine that serves your virtual host. This is almost certainly `navajos`.

It is ''expected'' that you don't have permission to read your logs in `/var/log/apache2`. Instead, use the handy `domtool-tail` program to view the logs in realtime. For instance, this command line will dump the last entries in the access log for www.domain.com, in the style of the UNIX `tail` program. We assume that you have Domtool permissions on domain.com.

{{{
domtool-tail [-n LINES] www.domain.com access
}}}

The optional `-n LINES` argument will fetch that many lines from the log.

You can view a graphical representation of your access logs by browsing our webalizer interface at [[https://members.hcoop.net/webalizer/]]. Its statistics are updated once per day.

= Permissions Issues (403 Access Denied) =
When you publish web content, it will probably live in your home directory. The web server will need permission to read your files, or it will return "403 Access Denied" errors. Since your home directory is in AFS, '''normal UNIX permissions are irrelevant'''.

For instance, if you get a 403 error serving `~/public_html/otherdir/page.html`, you might run this to see what's up:

{{{
$ fs listacl ~/public_html/otherdir
Access list for /afs/hcoop.net/user/y/yo/you/public_html/otherdir is
Normal rights:
  system:administrators rlidwka
  system:anyuser l
  you rlidwka}}}

Oops! Apache only matches the "system:anyuser" principal, so it only gets the "l" (= "list") permission and can only list your directory contents. Try this to fix it:

{{{
$ fs setacl ~/public_html/otherdir system:anyuser read
$ fs setacl ~/public_html system:anyuser read
$ fs setacl ~ system:anyuser l}}}

The first two give full read permission on the mentioned directories. "l" permission is needed in every parent directory of a file to be able to access it, so the last line makes sure "l" is granted to system:anyuser on your home directory.

When your web content is accessed through your own virtual host, you can also grant read access to `$USER.daemon` instead of the broader `system:anyuser`, where `$USER` is your username. This is your bizarro-world twin, which Apache runs as when serving your content.

Note that your CGI directories and executables should be in the group `nogroup`; if this is not the case you may see cryptic warnings in your `error.log` along the lines of `suexec policy violation: see suexec log for more details`.

See [[MemberManual/GettingStarted|the Getting Started chapter]] of the Member Manual, in particular the ''AFS'' section, for information on how to work with AFS's '''separate''' notion of permissions.

= Permissions Issues (500 Server Error for CGIs) =

If you get a 500 server error when running a CGI script, one likely cause is directory permissions. {{{suexec}}} will refuse to run a cgi if its parent directory is writeable by others. So, make sure permissions are set to 755 and not 775. Note that the directory permissions do not actually affect anything (since we're using AndrewFileSystem), but modifying the suexec code to skip the checks is considered too risky.

= Getting HTTPS access working =

In order to serve websites over HTTPS, you will need to generate an SSL certificate and optionally request an IP address from us.

 1. Either [[/SslCert|generate an SSL certificate yourself]], or buy one from somewhere (search for "ssl certificate" using your search engine of choice for a list of popular vendors).
 1. [[https://members.hcoop.net/portal/cert|Request permission to use your certificate for a domain]].
 1. Add a stanza to your DomTool configuration file. Examples of this may be found at [[DomTool/Examples]].

This will work for most for most people, but relies upon [[http://en.wikipedia.org/wiki/Server_Name_Indication|TLS SNI]] to work. This means that Windows XP users with Internet Explorer will get the generic `*.hcoop.net` certificate instead of your certificate. Supposedly, they account for less of the browsing public than GNU/Linux users do so you should almost never need a dedicated IP address just for SSL. However, if you do, and can justify it, we are [[https://members.hcoop.net/portal/ip|happy to provide you with one]] (we just don't have very many).
Line 3: Line 113:
CategoryOutdated CategoryMemberManual

This is the chapter of the MemberManual that describes how to serve your website(s).

Static Web Sites

If you plan on having static websites without any CGI such as php or perl, then read on. In your home directory, there is a directory named public_html. By default, you can access this at http://www.hcoop.net/~USER. You will never be able to execute server-side scripts when accessing webpages in that manner. If you're going to use a domain, please read the next section.

Dynamic Web Sites

If you plan on having a website that utilizes CGI such as php or perl, then you must either have a domain or an hcoop.net subdomain (i.e., USER.hcoop.net).

When you have chosen a domain to be hosted by HCoop, you then simply request control of that domain at the portal. Once it is authorized by an administrator, you will be able to utilize DomTool. DomTool will let Apache and other services know about your domain. Please take a look at using DomTool, DomTool user guide, and DomTool examples to learn how to do this. Our nameservers are ns1.hcoop.net and ns2.hcoop.net.

As a hint, DomTool configurations are stored in ~/.domtool/. Some users have made their production configurations readable and so you may be able to learn from them. See the bottom of DomTool examples to find out who is showing off their DomTool configurations.

If your web application needs write access to a data directory, give USER.daemon write permission to it and all of its subdirectories. In this example, be sure to replace USER with your username (lowercase):

fsr sa ./webdata USER.daemon write

Alternatively, use only fs if you need to set the ACL for just one directory.

For database help, take a look at this manual's Databases chapter.

To see how you can transfer files to HCoop, see the Transferring Files chapter.

In addition, .htaccess files are not processed on our servers. See DomTool Examples to learn how to use rewrite rules and other features normally provided by .htaccess.

PHP

The default will be (long overdue) changed to php5 before February 1, 2013. php4 is not available on our newest servers, so upgrading to php5 is highly recommended.

We use PHP 4 by default to serve .php files. We also have PHP 5 available for member use. If the script being executed has a .php4 or .php5 extension, then the script will use PHP 4 or PHP 5, respectively. To set the PHP version, use the phpVersion command as follows.

To use PHP 4 in a directory or virtual host:

phpVersion php4;

To use PHP 5 in a directory or virtual host:

phpVersion php5;

Common Web Applications

It is likely that another member has configured one of many common applications and documented it on the ../WebApplications page.

Running your own web server

Many popular Apache modules for "fast web serving," like mod_python and mod_perl, are incompatible with our security requirements; they force all Python, Perl, etc., scripts run through them to run as a single UNIX user. Thus, to use these modules, you will need to run your own separate web server. See RunningYourOwnApache.

It also couldn't hurt to petition the authors of these modules to fix this problem. ;-)

Examining your logs

The error and access logs are stored in ~/.logs/apache. They are separated by machine and domain. Your ~/.logs/apache directory is updated once every 20 minutes from the "real" logs in /var/log/apache2 on the machine that serves your virtual host. This is almost certainly navajos.

It is expected that you don't have permission to read your logs in /var/log/apache2. Instead, use the handy domtool-tail program to view the logs in realtime. For instance, this command line will dump the last entries in the access log for www.domain.com, in the style of the UNIX tail program. We assume that you have Domtool permissions on domain.com.

domtool-tail [-n LINES] www.domain.com access

The optional -n LINES argument will fetch that many lines from the log.

You can view a graphical representation of your access logs by browsing our webalizer interface at https://members.hcoop.net/webalizer/. Its statistics are updated once per day.

Permissions Issues (403 Access Denied)

When you publish web content, it will probably live in your home directory. The web server will need permission to read your files, or it will return "403 Access Denied" errors. Since your home directory is in AFS, normal UNIX permissions are irrelevant.

For instance, if you get a 403 error serving ~/public_html/otherdir/page.html, you might run this to see what's up:

$ fs listacl ~/public_html/otherdir
Access list for /afs/hcoop.net/user/y/yo/you/public_html/otherdir is
Normal rights:
  system:administrators rlidwka
  system:anyuser l
  you rlidwka

Oops! Apache only matches the "system:anyuser" principal, so it only gets the "l" (= "list") permission and can only list your directory contents. Try this to fix it:

$ fs setacl ~/public_html/otherdir system:anyuser read
$ fs setacl ~/public_html system:anyuser read
$ fs setacl ~ system:anyuser l

The first two give full read permission on the mentioned directories. "l" permission is needed in every parent directory of a file to be able to access it, so the last line makes sure "l" is granted to system:anyuser on your home directory.

When your web content is accessed through your own virtual host, you can also grant read access to $USER.daemon instead of the broader system:anyuser, where $USER is your username. This is your bizarro-world twin, which Apache runs as when serving your content.

Note that your CGI directories and executables should be in the group nogroup; if this is not the case you may see cryptic warnings in your error.log along the lines of suexec policy violation: see suexec log for more details.

See the Getting Started chapter of the Member Manual, in particular the AFS section, for information on how to work with AFS's separate notion of permissions.

Permissions Issues (500 Server Error for CGIs)

If you get a 500 server error when running a CGI script, one likely cause is directory permissions. suexec will refuse to run a cgi if its parent directory is writeable by others. So, make sure permissions are set to 755 and not 775. Note that the directory permissions do not actually affect anything (since we're using AndrewFileSystem), but modifying the suexec code to skip the checks is considered too risky.

Getting HTTPS access working

In order to serve websites over HTTPS, you will need to generate an SSL certificate and optionally request an IP address from us.

  1. Either generate an SSL certificate yourself, or buy one from somewhere (search for "ssl certificate" using your search engine of choice for a list of popular vendors).

  2. Request permission to use your certificate for a domain.

  3. Add a stanza to your DomTool configuration file. Examples of this may be found at DomTool/Examples.

This will work for most for most people, but relies upon TLS SNI to work. This means that Windows XP users with Internet Explorer will get the generic *.hcoop.net certificate instead of your certificate. Supposedly, they account for less of the browsing public than GNU/Linux users do so you should almost never need a dedicated IP address just for SSL. However, if you do, and can justify it, we are happy to provide you with one (we just don't have very many).


CategoryMemberManual

MemberManual/ServingWebsites (last edited 2021-02-24 02:47:00 by ClintonEbadi)