5.0-Nano: Perl: Difference between revisions

From The Uniform Server Wiki
Jump to navigation Jump to search
(Punctuation and grammatical changes; some clarification and additional explanation.)
Line 2: Line 2:
'''Uniform Server 5.0-Nano and Perl'''
'''Uniform Server 5.0-Nano and Perl'''


Although for server control Uniform Server no longer uses Perl it remains fully supported.
Although Uniform Server no longer uses Perl for server control, it remains fully supported.


Perl is a very powerful scripting language to do it justice two plugins are provided full and mini Perl.  
Perl is a very powerful scripting language. To do it justice, two plugins are provided: full and mini Perl.
 
Full-Perl as the name implies consists of the core program and all modules, while mini-Perl consists of the core program and a selection of commonly used Perl modules.


Full-Perl as the name implies consists of the core program and all modules while mini-Perl consists of the core program and a collection of commonly used Perl modules.


'''''[[#top | Top]]'''''
== ActivePerl ==
== ActivePerl ==
Uniform Server's Perl plugins use [http://www.activestate.com/activeperl/features/ ActivePerl] from [http://www.activestate.com/ ActiveState] current version is ActivePerl 5.10.1.1007 it’s an industry-standard Perl distribution.
Uniform Server's Perl plugins use [http://www.activestate.com/activeperl/features/ ActivePerl] from [http://www.activestate.com/ ActiveState]. The current version is ActivePerl 5.10.1.1007. It’s an industry-standard Perl distribution.


ActivePerl is multi platform, runs on Windows, Linux, Mac OS X, Solaris, AIX and HP-UX.
ActivePerl is multi platform and runs on Windows, Linux, Mac OS X, Solaris, AIX and HP-UX.


Apart from being robust and reliable one of its main features is portability.
Apart from being robust and reliable, one of its main features is portability.


'''''[[#top | Top]]'''''


== Plugins ==
== Plugins ==
There are two plugins to choose from either full or mini.
There are two plugins to choose from either full or mini. Each is available in the three following versions:


'''''Perl Versions'''''
'''''Perl Versions'''''
Line 26: Line 25:
*ActivePerl 5.10.1.1007
*ActivePerl 5.10.1.1007


The mini plugin is suitable for majority of smaller applications. Larger and more advanced application download the full plugin.
The mini plugin is suitable for majority of smaller applications. For more advanced applications, download the full plugin.
 


'''''[[#top | Top]]'''''
=== Download ===
=== Download ===
Downloaded the plugins from from [http://sourceforge.net/projects/miniserver/files/Plugins/Uniform%20Server%205-Nano%20Plugins/ Sourceforge] choose one of the following:
Download the plugins from [http://sourceforge.net/projects/miniserver/files/Plugins/Uniform%20Server%205-Nano%20Plugins/ Sourceforge] and choose one of the following:


'''ActivePerl 5.10.1.1005'''
'''ActivePerl 5.10.1.1005'''
Line 72: Line 71:
|}
|}


Non-Perl users I hope will appreciate what a significant overhead it is even with mini-Perl installed hence the reason for making Perl a plugin.
I hope non-Perl users will appreciate what a significant overhead this represents, even with mini-Perl installed, hence the reason for making Perl a plugin.


If space is at a premium Perl users can start with mini-Perl and add modules as required from full-Perl.  
If space is at a premium, Perl users can start with mini-Perl and add modules as required from full-Perl.  


'''''Note'':''' Don't mix modules from different versions.
'''''Note'':''' Don't mix modules from different versions.


'''''[[#top | Top]]'''''


=== Install ===
=== Install ===
Line 86: Line 84:


* Copy file V5.#_mini_perl.exe or V5.#_full_perl.exe to folder UniServer
* Copy file V5.#_mini_perl.exe or V5.#_full_perl.exe to folder UniServer
* Double click on file to run the self-extracting archive
* Double click on the file to run the self-extracting archive
* For Perl to be picked up restart the servers.
* For Perl to be picked up, restart the servers.


Creates two new folders bin and lib in folder UniServer\usr  
This creates two new folders, bin and lib, in folder UniServer\usr  
These contain the Perl program and Perl modules respectively.
These contain the Perl program and Perl modules respectively.


Line 103: Line 101:
These contain the Perl program and Perl modules respectively.
These contain the Perl program and Perl modules respectively.


'''''[[#top | Top]]'''''


== Support enabled ==
== Support enabled ==
UniServer automatically detects the presence of Perl and enables functionality to support it in both Apanel and UniTray.
UniServer automatically detects the presence of Perl and enables functionality to support it in both Apanel and UniTray.


'''''[[#top | Top]]'''''
 
=== Auto tracking ===
=== Auto tracking ===
Perl scripts are placed in folder UniServer\'''cgi-bin''' and any sub-folders as appropriate.
Perl scripts should be placed in folder UniServer\'''cgi-bin''' and any sub-folders as appropriate.
 
Each script requires a Shebang. This must be an absolute path to the Perl executable. For example:
Each script requires a shebang this must be an absolute path to the Perl executable for example:
<pre>
<pre>
#!C:/Test/UniServer/usr/bin/perl.exe
#!C:/Test/UniServer/usr/bin/perl.exe
</pre>
</pre>
Moving UniServer to another location automatically updates this shebang.
Moving UniServer to another location automatically updates this Shebang.
 
Server control, on detecting a server move, writes a new Shebang to all files with a '''.pl''' or '''.cgi''' extension.
Server control on detecting a server move writes a new shebang to all files with a '''.pl''' or '''.cgi''' extension.
 
An automatic update is initiated '''only''' when the servers are '''moved'''.
An automatic update is initiated '''only''' when the servers are '''moved'''.


'''''Important'''''
'''''Important'''''


After extracting a third party Perl script to cgi-bin you must either move the servers or '''force a shebang update''' using UniTray. Alternatively you can manually edit each file.
After extracting a third party Perl script to cgi-bin, you must either move the servers or '''force a Shebang update''' using UniTray. Alternatively, you can manually edit each file.


'''''[[#top | Top]]'''''


=== Apanel support ===
=== Apanel support ===
With Perl installed a new menu option become available in Apanel. This displays the Perl environment and additional information.       
A new menu option becomes available in Apanel when Perl is installed. This displays the Perl environment and additional information.       


'''''[[#top | Top]]'''''


=== UniTray support ===
=== UniTray support ===
==== Force shebang update ====
==== Force Shebang update ====
Perl scripts contain a Shebang (first line) this informs a server where to find the Perl program. Uniform Server is dynamic and tracks any path changes automatically updating the Shebang.
Perl scripts contain a Shebang (first line) which informs a server where to find the Perl program. Uniform Server is dynamic and tracks any path changes automatically updating the Shebang.


However if the server remains static and you have added new scripts in the cgi-bin folder the Shebang is never updated. Hence run the following menu item after installing new scripts. It updates the Shebang in all files to the current Perl location.
However if the server remains static and you have added new scripts in the cgi-bin folder the Shebang is never updated. Hence run the following menu item after installing new scripts. It updates the Shebang in all files to the current Perl location.
Line 145: Line 137:
'''''Tip'':'''
'''''Tip'':'''


When writing Perl scripts you can use the following for the shebang:
When writing Perl scripts you can use the following for the Shebang:
<pre>
<pre>
#!
#!
</pre>
</pre>
From UniTray run "Perl Shebang Update cgi-bin" and all pages will be updated with the correct shebang.  
From UniTray, run "Perl Shebang Update cgi-bin" and all pages will be updated with the correct shebang.  
   
   
'''''[[#top | Top]]'''''


==== Convert to Unix format ====
==== Convert to Unix format ====
Perl scripts developed on Windows will not run on a Unix machine they require conversion to Unix format.
Perl scripts developed on Windows will not run on a Unix machine. They require conversion to Unix format.
   
   
Run the conversion script from UniTray as follows:
Run the conversion script from UniTray as follows:
Line 166: Line 157:
Scripts in this new folder are converted from Windows to Unix format.
Scripts in this new folder are converted from Windows to Unix format.
*Converts end of line:  Dec(#10#13=>#13) Hex 0D0A to 0A
*Converts end of line:  Dec(#10#13=>#13) Hex 0D0A to 0A
*Replaces Windows shebang with Unix shebang
*Replaces Windows Shebang with Unix Shebang


'''''[[#top | Top]]'''''


== Related Topic Links ==
== Related Topic Links ==
[[Perl CGI Hello World | Perl CGI Hello World]] - Short snippets to get you started with Perl
[[Perl CGI Hello World | Perl CGI Hello World]] - Short snippets to get you started with Perl


'''''[[#top | Top]]'''''


== Summary ==
== Summary ==
Uniform Server has been pre-configured for Perl hence after installing either of the plugins Perl is ready to run scripts.
Uniform Server has been pre-configured for Perl, so after installing either of the plugins, Perl is ready to run scripts.


For convenience any Uniform Server plugin requiring Perl support such as AWStats come complete with mini-Perl and any additional modules required to support that plugin.  
For convenience, any Uniform Server plugin requiring Perl support, such as AWStats, come complete with mini-Perl and any additional modules required to support that plugin.  


[[5.0-Nano: UniTray | '''Next page''']] covers UniTray
[[5.0-Nano: UniTray | '''Next page''']] covers UniTray


'''''[[#top | Top]]'''''


----
----


[[Category: Uniform Server 5.0-Nano]]
[[Category: Uniform Server 5.0-Nano]]

Revision as of 18:03, 22 December 2010

 

Uniform Server 5.0-Nano and Perl

Although Uniform Server no longer uses Perl for server control, it remains fully supported.

Perl is a very powerful scripting language. To do it justice, two plugins are provided: full and mini Perl.

Full-Perl as the name implies consists of the core program and all modules, while mini-Perl consists of the core program and a selection of commonly used Perl modules.


ActivePerl

Uniform Server's Perl plugins use ActivePerl from ActiveState. The current version is ActivePerl 5.10.1.1007. It’s an industry-standard Perl distribution.

ActivePerl is multi platform and runs on Windows, Linux, Mac OS X, Solaris, AIX and HP-UX.

Apart from being robust and reliable, one of its main features is portability.


Plugins

There are two plugins to choose from either full or mini. Each is available in the three following versions:

Perl Versions

  • ActivePerl 5.10.1.1005
  • ActivePerl 5.10.1.1006
  • ActivePerl 5.10.1.1007

The mini plugin is suitable for majority of smaller applications. For more advanced applications, download the full plugin.


Download

Download the plugins from Sourceforge and choose one of the following:

ActivePerl 5.10.1.1005

File name Compressed Uncompressed Comments
V5.0_mini_perl.exe 5.07 MB 16.5 MB Contains Perl core program with a collection of commonly used Perl modules.
V5.0_mini_perl.zip 7.13 MB 16.5 MB Contains Perl core program with a collection of commonly used Perl modules.
V5.0_full_perl.exe 10.6 MB 52.2 MB Contains Perl core program and full set of Perl modules.
V5.0_full_perl.zip 16.0 MB 52.2 MB Contains Perl core program and full set of Perl modules.

ActivePerl 5.10.1.1006

File name Compressed Uncompressed Comments
V5.1_mini_perl.exe 5.14 MB 16.9 MB Contains Perl core program with a collection of commonly used Perl modules.
V5.1_mini_perl.zip 7.21 MB 16.9 MB Contains Perl core program with a collection of commonly used Perl modules.
V5.1_full_perl.exe 10.9 MB 54.1 MB Contains Perl core program and full set of Perl modules.
V5.1_full_perl.zip 16.5 MB 54.1 MB Contains Perl core program and full set of Perl modules.

ActivePerl 5.10.1.1007

File name Compressed Uncompressed Comments
V5.2_mini_perl.exe 5.17 MB 17.3 MB Contains Perl core program with a collection of commonly used Perl modules.
V5.2_mini_perl.zip 7.27 MB 17.3 MB Contains Perl core program with a collection of commonly used Perl modules.
V5.2_full_perl.exe 11 MB 55.2 MB Contains Perl core program and full set of Perl modules.
V5.2_full_perl.zip 16.7 MB 55.2 MB Contains Perl core program and full set of Perl modules.

I hope non-Perl users will appreciate what a significant overhead this represents, even with mini-Perl installed, hence the reason for making Perl a plugin.

If space is at a premium, Perl users can start with mini-Perl and add modules as required from full-Perl.

Note: Don't mix modules from different versions.


Install

exe

By far the easiest way to install Perl is to download one of the executables and install as follows:

  • Copy file V5.#_mini_perl.exe or V5.#_full_perl.exe to folder UniServer
  • Double click on the file to run the self-extracting archive
  • For Perl to be picked up, restart the servers.

This creates two new folders, bin and lib, in folder UniServer\usr These contain the Perl program and Perl modules respectively.

zip

Installing from a zip file requires a few extra steps as follows:

  • Copy file V5.#_mini_perl.zip or V5.#_full_perl.zip to any folder.
  • Extract to current path.
  • Copy folders bin and lib to folder UniServer\usr
  • For Perl to be picked up restart the servers.

These contain the Perl program and Perl modules respectively.


Support enabled

UniServer automatically detects the presence of Perl and enables functionality to support it in both Apanel and UniTray.


Auto tracking

Perl scripts should be placed in folder UniServer\cgi-bin and any sub-folders as appropriate. Each script requires a Shebang. This must be an absolute path to the Perl executable. For example:

#!C:/Test/UniServer/usr/bin/perl.exe

Moving UniServer to another location automatically updates this Shebang. Server control, on detecting a server move, writes a new Shebang to all files with a .pl or .cgi extension. An automatic update is initiated only when the servers are moved.

Important

After extracting a third party Perl script to cgi-bin, you must either move the servers or force a Shebang update using UniTray. Alternatively, you can manually edit each file.


Apanel support

A new menu option becomes available in Apanel when Perl is installed. This displays the Perl environment and additional information.


UniTray support

Force Shebang update

Perl scripts contain a Shebang (first line) which informs a server where to find the Perl program. Uniform Server is dynamic and tracks any path changes automatically updating the Shebang.

However if the server remains static and you have added new scripts in the cgi-bin folder the Shebang is never updated. Hence run the following menu item after installing new scripts. It updates the Shebang in all files to the current Perl location.


left click tray icon > Advance > click "Perl Shebang Update cgi-bin"


Tip:

When writing Perl scripts you can use the following for the Shebang:

#!

From UniTray, run "Perl Shebang Update cgi-bin" and all pages will be updated with the correct shebang.


Convert to Unix format

Perl scripts developed on Windows will not run on a Unix machine. They require conversion to Unix format.

Run the conversion script from UniTray as follows:


left click tray icon > Advance > click "Perl win2unix + Shebang Update"


This script copies all files in cgi-bin to a new folder \cgi-bin-unix\

Scripts in this new folder are converted from Windows to Unix format.

  • Converts end of line: Dec(#10#13=>#13) Hex 0D0A to 0A
  • Replaces Windows Shebang with Unix Shebang


Related Topic Links

Perl CGI Hello World - Short snippets to get you started with Perl


Summary

Uniform Server has been pre-configured for Perl, so after installing either of the plugins, Perl is ready to run scripts.

For convenience, any Uniform Server plugin requiring Perl support, such as AWStats, come complete with mini-Perl and any additional modules required to support that plugin.

Next page covers UniTray