Did you know ... | Search Documentation: |
Pack lps_corner -- swish/INSTALL_server.md |
The following applies to Linux Ubuntu, and is a collage of specific instructions for each part for convenience as of March 2017; refer to the original URLs below for more details and updates.
The simplest way to install LPS on SWISH is using a Docker container. Make sure you have Docker installed in your system, create two empty writeable directories, MyData and MyLogs, and then simply (for Mac and Linux):
docker run -p 3051:3050 \ -v /MyData:/data \ -v /MyLogs:/home/lps/engine/logs \ logicalcontracts/lps.swi
The above starts up a SWISH server with LPS at port 3051 on your system; to use it just take your browser to `http://localhost:3051
`.
For more details please see the dockerfile.
Pls see instructions from your cloud provider.
Please refer to SWI Prolog's site
cd ~ sudo apt-get update sudo apt-get upgrade sudo apt-get install unzip sudo apt-get install \ build-essential autoconf curl chrpath pkg-config \ ncurses-dev libreadline-dev libunwind-dev \ libgmp-dev \ libssl-dev \ unixodbc-dev \ zlib1g-dev libarchive-dev \ libossp-uuid-dev \ libxext-dev libice-dev libjpeg-dev libxinerama-dev libxft-dev \ libxpm-dev libxt-dev \ libdb-dev \ openjdk-8-jdk junit # Optional (doc), consider avoiding as it requires about 3Gb: sudo apt-get install \ texlive-latex-extra \ texlive-fonts-extra \ texlive-fonts-extra-doc \ texlive-fonts-recommended \ texlive-fonts-recommended-doc # Optional, to avoid some error messages later: sudo apt-get install libpcre3-dev git clone https://github.com/SWI-Prolog/swipl-devel.git cd swipl-devel ./prepare (confirm with yes) ./configure make sudo make install cd packages ./configure make sudo make install
Please refer to the SWISH README file.
cd ~ sudo apt-get install graphviz sudo apt-get install nodejs sudo apt install nodejs-legacy sudo apt install npm sudo npm install -g bower cd ~ git clone https://github.com/SWI-Prolog/swish.git cd swish git submodule update --init bower install #as of now, this seems to be missing from the previous step and must be performed too: #bower install jquery-ui make src
Ideally minify swish referring to its documentation, or at least comment line swish/web/js/swish.js:47:
urlArgs: "ts="+new Date().getTime(), /* prevent caching during development */
cd ~ git clone https://bitbucket.org/lpsmasters/lps_corner.git # In what follows replace lps_corner by the name of your own directory if necessary: cd lps_corner/engine mkdir logs chmod a+w logs # ...or something finer cd ~/lps_corner/swish mkdir data chmod a+w data # ...or something finer cd ~/lps_corner/swish/web/lps ./INSTALL.sh # install bower components # You might want to TEST now: # cd ~/lps_corner/swish # sudo swipl user_module_file.pl ../../swish/daemon.pl --port=80 --no-fork --user=www-data --workers=16 # ... and open a browser upon your virtual machine address # Google Analytics (optional): # with sftp, put googleAnalyticsKey file (containing only the key) into lps_corner/swish # Setup operation as service (Using upstart) sudo apt install upstart sudo reboot sudo apt-get install upstart-sysv sudo reboot cd /etc/init sudo ln -s ~/lps_corner/swish/upstart/lps.conf . sudo start lps # then use # sudo stop lps # sudo restart lps
For HTTP (SWI/SWISH) logging: give write permission to www-data in ~/swish. It may also be necessary to review permissions of lps_corner/swish/postmortems.
Replace the final sequence above with the following:
# Setup operation as service (Using systemd, e.g. Ubuntu 17.0) cd /lib/systemd/system sudo ln -s ~/lps_corner/swish/systemd/lps.service . sudo systemctl enable lps.service sudo systemctl daemon-reload sudo systemctl restart lps.service # then use # sudo systemctl stop lps.service # systemctl status lps.service
For both Upstart and systemd, revise the environment variable `HOSTING
` set in the configuration scripts, which may restrict LPS system capabilities. Also check that the working directory set for the service exists in your system.
At https://console.aws.amazon.com/cloudwatch:
sudo apt-get install libwww-perl libdatetime-perl curl http://aws-cloudwatch.s3.amazonaws.com/downloads/CloudWatchMonitoringScripts-1.2.1.zip -O unzip CloudWatchMonitoringScripts-1.2.1.zip rm CloudWatchMonitoringScripts-1.2.1.zip cd aws-scripts-mon crontab -e # add this and save: */5 * * * * ~/aws-scripts-mon/mon-put-instance-data.pl --mem-util --disk-space-util --disk-path=/ --from-cron
Then define alarms and email notifications at the Cloud Watch console.
By configuring SWISH authentication, the predicate `lps_user(-User)
` returns a unique user reference as given by the authentication service, such as Google or SWISH's own auth_http (the only ones tested so far). Unauthenticated users are mapped into the single user account `unknown_user
.
To configure authentication for Google accounts, follow the instructions at swish/config-available/README.md (namely copying `swish/config-available/auth_google.pl
` to directory `swish/config-enabled/
` ) and (specially) at the top of swish/config-available/auth_google.pl, editing that file as indicated plus:
`oauth2:server_attribute(google, scope,email).
``name(UserInfo.name)
by
name(UserInfo.email)
For **HTTP** authentication, copy/link
config-available/auth_http.pl
to
`config-enabled/`. You also need to create a passwd file in
lps_corner/swish
``, following the SWISH instructions.