Skip to content

Latest commit

 

History

History
294 lines (233 loc) · 12 KB

GettingStarted.md

File metadata and controls

294 lines (233 loc) · 12 KB

Installation

  • To develop and contribute new code, see below on Sharing Your Work. If you only want to run a copy of the site, move into a new directory and type

       git clone https://github.com/LMFDB/lmfdb.git lmfdb
    

    and follow these instructions.

  • Make sure you have Sage (>=7.0) installed and that sage is available from the commandline. In particular see Sage installation. Also check that your version of Sage has ssl available by checking that import ssl works on its command line. If not, then the pip install commands below will fail. To remedy this, either install SSL globally on your system or have Sage build its own local version, as mentioned here and here, respectively.

  • Install dependencies. This requires you to have write access to the Sage installation directory, so should be no problem on a personal machine, but if you are using a system-wide Sage install on a shared machine, you will need ask a system administrator to do this step.

       sage -i gap_packages
       sage -i database_gap
       sage -i pip
       sage -b
       # in the 'lmfdb/' directory:
       sage -pip install -r requirements.txt
    

    Troubleshooting with packages.

    • If you have not run the site for a while you might get an error with packages like

        ImportError: cannot import name monitoring
      

      In this case or if you need to upgrade for any reason run

        sage -pip install -r requirements.txt --upgrade
      
    • In case the last step fails due to some missing SSL library, (this may be the case on osX) follow these steps

      sage -i openssl
      sage -f python2 # takes some time
      sage -i pyopenssl
      sage -pip install --upgrade pip
      sage -pip install -r requirements.txt
      
    • [optional] Memcache. This step is not at all necessary and can safely be ignored! Memcache speeds up recompilation of python modules during development. Using it requires both installing the appropriate package for your Operating System and installing an additional python module. The first line below needs to be run in a Sage shell, and the for second you need to be a super-user to install memcached if your machine does not have it.

      • easy_install -U python-memcached

      or even better and only possible if you have the dev headers:

      • easy_install -U pylibmc

      • install memcached (e.g. apt-get install memcached) and run the service at 127.0.0.1:11211

Running

  • A read-only copy of the database is hosted at m0.lmfdb.xyz. This is what is used by default. You can launch the webserver directly like this:

        sage -python start-lmfdb.py --debug
    
  • The effect of the (optional) --debug is that you will be running with the beta flag switched on as at beta.lmfdb.org, and also that if code fails your browser will show useful debugging information. Without --debug what you see will be more like www.lmfdb.org.

  • Once the server is running, visit http://localhost:37777/

    You should now have a fully functional LMFDB site through this server.

  • When running with --debug, whenever a python (*.py) file changes the server will reload automatically. If you save while editing at a point where such a file is not syntactically correct, the server will crash and you will need to start_lmfdb again. Any changes to html files will not cause the server to restart, so you will need to reload the pages in your borowser. Changes in the yaml files which are read only once at startup will require you to manually stop the server and restart it.

  • If you don't have access to this server, you can temporarily start your own mongodb server and use it locally. There is no data (obviously) but it will work. To start mongo locally (after installing mongo on your machine):

       mongod --port 37010 --dbpath [db_directory] --smallfiles
    
  • You may have to suppress loading of your local python libraries: sage -python -s start-lmfdb.py

  • If you use a local MongoDB instance, specify its port: sage -python start-lmfdb.py --debug --mongo-port 40000 --mongo-host localhost

  • If several people are running their own version of the webserver on the same machine, they cannot all use port 37777 -- if they try, they can get very confused. In such a scenario, all involved should agree to using a sequence of port numbers from 37700 upwards and allocate one such number to each user, then add it to the command line: e.g.

       sage -python ./start-lmfdb.py --debug -p 37702
    

    To avoid having to remember that, it is a good idea to define an alias for this. e.g. with bash you can insert the line

    function start_lmfdb () { sage -python ./start-lmfdb.py --debug -p 37702;}
    

    in your .bashrc file, so that all you have to type to start the server is start_lmfdb.

  • It is possible to use a different instance of the database. For many uses, using the default configuration (which uses a read-only database on m0.lmfdb.xyz) is sufficient, and this step is not necessary. If you do plan on using a different database instance, it's a good idea to copy default_mongoclient.config to mongoclient.config and to change the entries in mongoclient.config to your access point for the database.

    One possibility is to connect to the lmfdb database on the machine lmfdb.warwick.ac.uk, using ssh tunelling so that your local machine's port 27017 (where the website code expects the database to be running) maps to the same port number on the database server. (Note that in the past, the default port has also been 37010). For this to work you must first send your public SSH key (as an email attachment preferably) to Harald Schilly, Jonathan Bober or John Cremona who will install it on the database server lmfdb.warwick.ac.uk. To make life easier, the necessary ssh command is in the lmfdb root directory in the script warwick.sh, so just type

       ./warwick.sh &
    

    The ampersand here makes this run in the background, so you should not have to run this more than once unless you close the current shell or logout.

Troubleshooting

If the pymongo module is not able to connect to the database, make sure that the warwick.sh script is still running.

[warning] Recently on some linux machines, users have had to install the contents of requirements.txt by manually. If the above instructions do not work, un-install the above packages and re-install them one at a time, including those in requirements.txt.

Code development and sharing your work

  • Get a (free) github account if you do not have one already.
  • Login to github
  • Go to https://github.com/LMFDB/lmfdb and click on Fork in the upper right corner.
  • On your machine, create a new directory and type
    git init
    git clone [email protected]:YourGithubUserId/lmfdb.git

using your own github user id. Your github repository will be known to git as a remote called origin.

  • Add the (official) LMFDB repository as a remote called upstream.
    git remote add upstream [email protected]:LMFDB/lmfdb.git
  • To run LMFDB, go through the rest of the instructions in Installation and Running.

  • You should make a new branch if you want to work on a new feature. The following command creates a new branch named new_feature and switches to that branch, after first switching to the master branch and making sure that it is up-to-date:

    git checkout master
    git pull upstream master
    git checkout -b new_feature
  • After making your local changes, testing them and committing the changes, push your branch to your own github fork:
    git push -u origin new_feature
  • Here, the option -u tells git to set up the remote branch origin/new_feature to be the corresponding upstream branch you push to.

  • You should make sure from time to time that you pull the latest changes from the official LMFDB repository. There are three branches upstream to be aware of: prod, beta and master:

- `prod` is changed rarely and contains the code currently running at
  www.lmfdb.org
- `beta` is changed more often and contains the code currently running at
  beta.lmfdb.org
- `master` is the development branch.

Normal developers only need to be aware of the master (=development) branch.

  • To pull in the most recent changes there to your own master branch locally and update your github repository too:
```
git checkout master
git pull upstream master
git push origin master
```
  • To rebase your current working branch on the latest master:
git pull --rebase upstream master
  • Tell the lmdb mailing list that you have some new code! You should also issue a pull request at github (from your feature branch new_feature) at the same time. Make sure that your pull request is to the lmfdb master branch, whatever your own development or feature branch is called. Others will review your code, and release managers will (eventually, if all is well) merge it into the master branch.

LMFDB On Windows

We do not recommend attempting to run LMFDB from within the Sage virtual image. For anyone who would like to attempt it, the following steps should theoretically work.

  • Download VirtualBox and the Sage appliance, following the instructions here.
  • The default Sage appliance does not have enough space to install LMFDB's prerequisites. Moreover, the default file type (vmdk) installed by VirtualBox does not support resizing. You will need to increase the available space by cloning into a vdi file, increasing the space and cloning back, following the instructions here and here. We had trouble at this stage: make sure to keep the .ova file in case you screw up your virtual image.
  • The resulting disk image needs to be repartitioned to make the space available. Unfortunately, the Sage appliance does not include gparted, the linux partition editor. So, you'll need to install gparted into the appliance (perhaps following instructions here) and use it to repartition.
  • You now need to set up port forwarding so that the sage appliance can use the ports 37777 and 37010 used by lmfdb. See Section 6.3.1 here.
  • Clone the LMFDB git repository into your host OS, and set up shared folders so that you can access the LMFDB code from within the Sage appliance. See the Sage instructions for how to share folders.
  • Now you need to run ssh-keygen within the Sage appliance and e-mail the result to Harald Schilly, Jonathan Bober or John Cremona (see above). Since copy-and-paste can be tricky from inside the virtual image, we suggest writing to a file shared by the host OS.
  • The instructions for Linux/OS X should now work. You should be able to forward the mongo database and run sage -python start-lmfdb.py within the Sage appliance, and access the resulting website from your host OS' web browser.