Differences between revisions 1 and 34 (spanning 33 versions)
Revision 1 as of 2011-12-19 20:13:16
Size: 7057
Editor: vbraun
Comment:
Revision 34 as of 2013-02-26 17:17:18
Size: 14350
Editor: kcrisman
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
#pragma section-numbers on
Line 3: Line 5:
This page describes how to use the virtual machine that you can download from [[http://www.sagemath.org/download-windows.html]]. If you want to create your own virtual machine, go to the [[VirtualBox]] wiki page instead.


== Requirements ==
This page describes how to use the Sage appliance that you can download from [[http://www.sagemath.org/download-windows.html]]. This page covers Sage versions 5 and higher; For previous versions see [[SageApplianceV4|the old manual]].

<<TableOfContents(3)>>



= Installation =
Line 9: Line 14:
VirtualBox player, for example Microsoft Windows. Your computer must
have at least 2.5 GB (!) of free disk space and at least 512 MB of RAM. The virtual machine can also be used with other hypervisors like VMware. However, unless you are already familiar with VMware, we recommend that you use !VirtualBox. In our experience, it is easier for non-technical users.

== Installation ==

  1. Download VirtualBox (available at http://www.virtualbox.org/wiki/Downloads). Install it anywhere you want. Version 4 or later is required.

  1. Download the file Sage-x.y.z.ova located in the directory where this README is.

  1. Open !VirtualBox. Import `sage-x.y.z.ova` by clicking '''File''', then '''Import Appliance'''. Make sure you read the '''Information''' boxes that appear, as they explain how to type and use the mouse pointer in the running !VirtualBox window.
  
  1. If you only want to access Sage through the web browser notebook interface (i.e., to write or run worksheets), you do not need to complete any further installation. You may go on to the next section to find out how to use Sage.

  1. If you want to enable shared folders between Sage and your Windows system, complete the following steps:

   a. In the running VirtualBox window, click '''Devices''', then '''Shared Devices'''.

   a. Click on the icon with a green '''+''' in the upper right corner.

   a. Select the path of the Windows folder that you want to share.

   a. Check '''auto-mount''' and '''make permanent'''. Click '''OK''', then click '''OK''' again.

   a. From the menu, select '''Machine''', then '''Reset'''. The files will be in `/media/sf_<volume name>`.


== Using the Sage Notebook ==

  1. Start VirtualBox.

  1. To start the Sage notebook server, power on Sage-x.y.z by selecting
  it and clicking 'Start'. (This may take awhile. You may see some
  warning messages you can safely ignore.)

  1. Wait a few moments until the running VirtualBox window displays a
message saying "Open your web browser to ..." Open your web broswer
(it's best to use Firefox) to the address specified.

  1. Login with username 'admin' and the password you selected upon
installing Sage.

  1. If you would like other users to be able to create additional accounts
!VirtualBox player, for example Microsoft Windows. Your computer must
have at least 7 GB (!) of free disk space and at least 512 MB of RAM. The virtual machine can also be used with other hypervisors like VMware. However, unless you are already familiar with VMware, we recommend that you use !VirtualBox. In our experience, it is easier for non-technical users.

If you are familiar with !VirtualBox, you can just import the Sage appliance. For detailed step-by-step instructions, please see the [[SageApplianceInstallation|installation instructions]] page for details.


= Using the Sage Notebook =

== Start VirtualBox ==

First, start !VirtualBox. To start the Sage notebook server, power on Sage-x.y.z by selecting
it and clicking 'Start'. (This may take awhile. You may see some
warning messages you can safely ignore.)

== Information Window ==

You may see an '''Information''' window explaining how to integrate the mouse pointer with the virtual machine:

  {{attachment:12mouse_pointer.JPG}}


== Using Sage ==

After the virtual machine has finished booting, you should see the following window:

  {{attachment:20_VM_notebook.png}}

You can now use Sage directly from here. Alternatively, you can minimize the
!VirtualBox window, open the web
browser that you usually use (it's best to use Firefox or Chrome), and
go to the address [[http://localhost:8000]]. Either way, you will see the
Sage notebook.

If you would like other users to be able to create additional accounts
Line 52: Line 49:
further steps in the Sage shell (see the next section on how to use the
Sage shell).

  1. When you are finished working with Sage, logout and close your browser
as usual. In the running VirtualBox window, click 'Machine', then 'Close'.
Select 'Power off the machine' then click 'OK'. You may now close
VirtualBox.


== Using the Sage shell ==

  1. Start VirtualBox if you have not already done so.

  1. Power on Sage-x.y.z (if you have not already done so) by selecting it
  and clicking 'Start'.

  1. Once the virtual machine is powered on, press 'Ctrl C' twice to quit
  the Sage notebook.

  1. Type './sage' to start a shell interface in Sage.
further steps. See the advanced options section below.


== Closing Sage ==

When you are finished working with Sage, close your browser
as usual (it is not necessary to '''Sign Out'''). In the running
!VirtualBox window, click '''Machine''', then '''Close''':

  {{attachment:15close.JPG}}

Select '''Send the shutdown signal''' then click '''OK''':

  {{attachment:16close.JPG}}

The running window will closed automatically, and then you may close !VirtualBox.


= Sharing files between Sage and Windows =

If you want to enable shared folders between Sage and your Windows system, complete the following steps:

  1. In the running !VirtualBox window, click '''Devices''', then '''Shared Folders''':

  {{attachment:8shared_folders.JPG}}

  1. Click on the icon with a green '''+''' in the upper right corner:

  {{attachment:9shared_folders.jpg}}

  1. Under '''Folder Path''', browse to select the path of the Windows folder that you want to share using the pull-down menu and selecting '''Other''':

  {{attachment:10shared_folders.JPG}}

  1. Check '''Auto-mount''' and '''Make Permanent'''. Click '''OK''', then click '''OK''' again. (Note, there may not be a '''Make Permanent''' option.)

  1. From the menu, select '''Machine''', then '''Reset''':

  {{attachment:11shared_folders.JPG|align="center"}}

The files will be in `/media/sf_<volume name>`.

= Using the Sage shell =

  1. Start !VirtualBox if you have not already done so.

  1. Power on `sage-x.y.z` (if you have not already done so) by selecting it
  and clicking '''Start'''.

  1. Once the virtual machine is powered on, simultaneously press '''Right-Ctrl''' and '''F1'''
  to switch to a console window. Note: '''Right-Ctrl''' is what !VirtualBox calls the
  host key, and you can change it in the settings. If you did change the hostkey, you have to
  use the new key combination in the following.

  1. Log in as user `sage` with password `sage`.

  1. If you get a black screen with a cursor blinking in the top left corner, simultaneously press '''Right-Ctrl''' and '''F1''' again. This is because the login script switches to a different console, and will be improved in the future.

  1. Type
  {{{
cd ~/sage
./sage
  }}}
  on the command line to start a shell interface in Sage.
Line 74: Line 115:
  enabled), type 'attach /media/sf_<volume name>/filename'

  1. Advanced users may want to note that Sage is not
  release 4.7, so you may need to type 'su' (password: sage), or press Alt-F1
  to get a different tty and login as root, if they have trouble with file
  permissions. These are advanced options, and you should be careful when
  accessing or altering files.


== Troubleshooting ==
  enabled), type
  {{{
attach /media/sf_<volume name>/filename
  }}}
  in the Sage command line session.

  1. Press '''Right-Ctrl''' and '''F2''' to return to the graphical Sage window.


= Troubleshooting =
Line 93: Line 134:
== Advanced Options ==

  * You can log into the virtual machine from the text-mode console. Press Alt-F1 for a different tty. The user account running the Sage notebook server is called `sage` with password `sage`. The root account password is `sage`, too.
= Advanced Options =

  * You can log into the virtual machine from the text-mode console. Press '''Right-Ctrl''' and '''F1''' for a different tty. The user account running the Sage notebook server is called `sage` with password `sage`. The root account password is `sage`, too.

  * You can also log into the virtual machine via ssh to port 2222. For example, with the command-line ssh client you would type
  {{{
ssh -p 2222 localhost
  }}}
  on the host computer to log into the virtual machine.
Line 99: Line 146:


2. To allow for the creation of new users (other than 'admin') on your local
   virtual machine,

   a. Type 'cd', then hit 'Enter'

   b. Type 'nano .bash_profile'

   c. At the end of the line that begins with 'notebook', type ',accounts=True',
      then hit 'Enter'.

   d. Type 'exit'
  * List available optional packages with the `optional_packages()`
  command and type `install_package('exact package name')` to install a
  package. You can do this from an input box in the notebook.

  * To upgrade between stable releases, you can type the following
  at the command prompt:
  {{{
[sage@localhost sage]$ sage -upgrade
  }}}
  Running an upgrade will take a significant amount of time.
  This ''will'' merge your changes to the Sage library with the
  latest version of Sage and build everything.

  WARNING: This will use up more disk space and is ''not'' guaranteed to
  result in a working upgraded Sage installation.


== Changing the keyboard layout ==

=== For the graphical web browser ===

The easiest way to use your keyboard layout of choice is to use the host browser and connect to the Sage server running at http://localhost:8000. However, if you want to permanently change the layout in the virtual machine browser, you can do this as follows:

  1. Log into the virtual machine as user `gui`. For example, you can log into the virtual machine from the text-mode console: Press '''Right-Ctrl''' and '''F1''' for a different tty. The user account running the web browser is called `gui` with password `sage`. See the advanced options section for more details.

  1. Edit the `gui` user's `.xinitrc` file:
  {{{
sagevm login: gui
Password:
Last login: Tue Jul 12 13:32:39 on tty9
[gui@sagevm ~]# nano .xinitrc
  }}}
  and add `setxkbmap <keyboard-coutry-code>` as the first line. The country code is usually the two-character country code, for example `de`, `gb`, `fi`, `fr`, ... To use the dvorak keyboard layout you would write
  {{{
setxkbmap dvorak
  }}}
  The complete list is described in `/usr/share/X11/xkb/rules/base.lst`.

  1. Save: Press '''Ctrl-X''' to exit, '''y''' to save, '''Enter''' to save it under the previous name `.xinitrc`

  1. Reboot the virtual machine to switch to the new keyboard layout.


=== Manually changing the layout on the console ===

To temporarily change the keyboard layout (for example, French AZERTY), you can drop to the shell and run the command
{{{
sudo loadkeys azerty
}}}
To make this change permanent, you have to edit a configuration file. Run
{{{
sudo nano /etc/sysconfig/keyboard
}}}
and set it to the following:
{{{
KEYTABLE="fr-latin1"
MODEL="pc105+inet"
LAYOUT="fr"
}}}

== Giving Others Access to the Sage Virtual Machine ==

You can run the Sage appliance as a server on the network, so that others can access it similar to [[http://www.sagenb.org]]. In this case, you have to make some changes to the virtual machine such that not everybody can log in.

  1. Log into the virtual machine as root: In the virtual machine, press `Alt-F1`, log in as user `root` with password `sage`. See the advanced options section for more details.

  1. Once you are logged in as root, change the password for the `root`, `sage` user (running the notebook server), and `gui` user (running the browser) account:
  {{{
[root@sage ~]# passwd root
Changing password for user root.
Retype new password:
passwd: all authentication tokens updated successfully.
[root@sage ~]# passwd sage
Changing password for user sage.
Retype new password:
passwd: all authentication tokens updated successfully.
[root@sage ~]# passwd gui
Changing password for user gui.
Retype new password:
passwd: all authentication tokens updated successfully.
  }}}

  1. Now switch to the sage account. You can either log in as sage with the new password, or type
  {{{
[root@sage ~]# su sage
[sage@sage root]$ cd
[sage@sage ~]$
  }}}

  1. Configure the notebook server to start in a secure mode. (These instructions are for versions previous to 5.4; some options changed at this time.) For this, you have to edit the `.bash_profile` file in the sage account. For example, type
  {{{
[sage@sage ~]$ nano .bash_profile
  }}}
  and replace the line
  {{{
./sage -notebook interface=\'\' port=8000 open_viewer=False require_login=False
  }}}
  with
  {{{
./sage -notebook interface=\'\' port=8000 open_viewer=False require_login=True secure=True
  }}}
  Then press `Ctrl X` to exit, and `y` when nano asks you to save the file before exiting (save it again as `.bash_profile`).

  1. Now reboot the virtual appliance:
  {{{
[sage@sage ~]$ exit
exit
[root@sage ~]# reboot
  }}}
Line 113: Line 256:
   e. This enables a link on the Sage notebook login in the web browser that
      reads 'Sign up for a new Sage Notebook account'. Users can then click on
      the link and follow the instructions to create a new account.

3. List available optional packages with the optional_packages()
   command and type install_package("exact package name") to install a
   package. You do this from an input box in the notebook.

4. Upgrading: To upgrade between stable releases, you can type "sage -upgrade"
   at the command prompt:

      [sage@localhost sage]$ sage -upgrade
      ...
      takes a while

    This *will* merge your changes to /usr/local/sage/devel/ with the
    latest version of Sage and build everything.

    WARNING: This will use up more disk space and is *not* guaranteed to
    result in a working upgraded Sage installation.



== How to be a Sage developer (even more advanced) ==
  1. Upon the reboot, Sage will ask for some further information. You will find the following in the VirtualBox window:
  {{{
----------------------------------------------------------------------
| Sage Version ..., Release Date: ... |
| Type notebook() for the GUI, and license() for information. |
----------------------------------------------------------------------

Please wait while the Sage Notebook server starts...
...
notebook(interface=r'''''''',port=8000,open_viewer=False,require_login=True,secure=True)
The notebook files are stored in: sage_notebook.sagenb
In order to use an SECURE encrypted notebook, you must first run notebook.setup().
Now running notebook.setup()
Domain name [localhost]:
  }}}
  Simply press return to use the default domain name. A SSL cryptographic key is then automatic created with this hostname.
  
  1. Now set up an admin password for the Sage notebook server. Unless you have set up such an account previously, Sage will ask you for a password automatically:
  {{{
Please choose a new password for the Sage Notebook 'admin' user.
Do _not_ choose a stupid password, since anybody who could guess your password
and connect to your machine could access or delete your files.
NOTE: Only the md5 hash of the password you type is stored by Sage.
You can change your password by typing notebook(reset=True).

Enter new password:
  }}}
  Please enter a new password following the instructions.

  1. Optional: Once your Sage server is secured, you can make it accessible from the network. For this, you have to stop the virtual machine (not just suspend it). Then, in the !VirtualBox window, go to '''Settings''' -> '''Network''' -> '''Adapter 1'''. It does say '''Attached to: NAT'''. Switch it to '''Bridged Adapter'''. Click OK and restart the virtual machine. Note: This makes your virtual machine accessible from the network. Only perform this step after you have changed passwords and configured the notebook server to be secure, as described above.

  1. Optional: Give the Sage virtual machine more resources, so it can server more clients. Go to '''Settings''' -> '''System'''. On the '''Motherboard''' tab, increase '''Base Memory''' to about half of the physical ram of your host computer. On the '''Processor''' tab, increase the number of processors to your host CPU number of cores. Finally, on the '''Acceleration''' tab, enable VT-x/AMD-V if your CPU supports this.

To connect to the Sage server, you have to use `https://...` instead of `http://...`. For example, on the host computer where the virtual machine is running, the Sage server listens at [[https://localhost:8000]]. Since our SSL key is not signed by a certificate authority (which you can do, but it does cost money) web browsers will show a warning that the authority of the key cannot be verified. While a signed SSL key would provide a higher level of security, the network data between the browser and the Sage server is nevertheless encrypted.




== How to become a Sage developer ==
Line 141: Line 299:
  1. Change to the SAGE_ROOT directory:

     
[sage@localhost directory]$ cd
     [sage@localhost ~]$ cd sage
     [sage@localhost sage]$

  2
. To actually edit files, you'll perhaps want to install the editor
  1. Change to the `$SAGE_ROOT` directory:
  {{{
[sage@localhost directory]$ cd
[sage@localhost ~]$ cd sage
[sage@localhost sage]$
  }}}

  1
. To actually edit files, you'll perhaps want to install the editor
Line 149: Line 308:

   [sage@localhost sage]$ apt-get inst
      ...
  {{{
[sage@localhost sage]$ sudo yum install emacs
  }}}
Line 155: Line 313:
Line 157: Line 314:

   [sage@localhost sage]$ cd devel/sage/sage/rings/
     [sage@localhost rings]$ emacs arith.py
     [edit the file]
  {{{
[sage@localhost sage]$ cd devel/sage/sage/rings/
[sage@localhost rings]$ emacs arith.py
  }}}
Line 163: Line 319:

     
[sage@localhost rings]$ nano arith.py
     [edit the file]

  4
. Save the file and type "sage -br" to build the changes and install them.

     
[sage@localhost rings]$ cd
     [sage@localhost ~]$ cd sage
     [sage@localhost sage]$ sage -br
     ----------------------------------------------------------
     
sage: Building and installing modified SAGE library files.
     ...
     ----------------------------------------------------------------------
     
| SAGE Version x.y.z, Release Date: .........
  {{{
[sage@localhost rings]$ nano arith.py
  }}}
  and
edit the file to your heart's content.

  1
. Save the file and type '''sage -br''' to build the changes and install them:
  {{{
[sage@localhost rings]$ cd
[sage@localhost ~]$ cd sage
[sage@localhost sage]$ sage -br
----------------------------------------------------------
sage: Building and installing modified SAGE library files.
...
----------------------------------------------------------------------
| SAGE Version x.y.z, Release Date: .........
  }}}

1. The Sage Virtual Machine

This page describes how to use the Sage appliance that you can download from http://www.sagemath.org/download-windows.html. This page covers Sage versions 5 and higher; For previous versions see the old manual.

2. Installation

The Sage appliance (packaged virtual machine) can be used on any operating system that supports the free VirtualBox player, for example Microsoft Windows. Your computer must have at least 7 GB (!) of free disk space and at least 512 MB of RAM. The virtual machine can also be used with other hypervisors like VMware. However, unless you are already familiar with VMware, we recommend that you use VirtualBox. In our experience, it is easier for non-technical users.

If you are familiar with VirtualBox, you can just import the Sage appliance. For detailed step-by-step instructions, please see the installation instructions page for details.

3. Using the Sage Notebook

3.1. Start VirtualBox

First, start VirtualBox. To start the Sage notebook server, power on Sage-x.y.z by selecting it and clicking 'Start'. (This may take awhile. You may see some warning messages you can safely ignore.)

3.2. Information Window

You may see an Information window explaining how to integrate the mouse pointer with the virtual machine:

  • 12mouse_pointer.JPG

3.3. Using Sage

After the virtual machine has finished booting, you should see the following window:

  • 20_VM_notebook.png

You can now use Sage directly from here. Alternatively, you can minimize the VirtualBox window, open the web browser that you usually use (it's best to use Firefox or Chrome), and go to the address http://localhost:8000. Either way, you will see the Sage notebook.

If you would like other users to be able to create additional accounts on the same local virtual machine, you will first need to complete some further steps. See the advanced options section below.

3.4. Closing Sage

When you are finished working with Sage, close your browser as usual (it is not necessary to Sign Out). In the running VirtualBox window, click Machine, then Close:

  • 15close.JPG

Select Send the shutdown signal then click OK:

  • 16close.JPG

The running window will closed automatically, and then you may close VirtualBox.

4. Sharing files between Sage and Windows

If you want to enable shared folders between Sage and your Windows system, complete the following steps:

  1. In the running VirtualBox window, click Devices, then Shared Folders:

    8shared_folders.JPG

  2. Click on the icon with a green + in the upper right corner:

    9shared_folders.jpg

  3. Under Folder Path, browse to select the path of the Windows folder that you want to share using the pull-down menu and selecting Other:

    10shared_folders.JPG

  4. Check Auto-mount and Make Permanent. Click OK, then click OK again. (Note, there may not be a Make Permanent option.)

  5. From the menu, select Machine, then Reset:

    align="center"

The files will be in /media/sf_<volume name>.

5. Using the Sage shell

  1. Start VirtualBox if you have not already done so.

  2. Power on sage-x.y.z (if you have not already done so) by selecting it and clicking Start.

  3. Once the virtual machine is powered on, simultaneously press Right-Ctrl and F1 to switch to a console window. Note: Right-Ctrl is what VirtualBox calls the host key, and you can change it in the settings. If you did change the hostkey, you have to use the new key combination in the following.

  4. Log in as user sage with password sage.

  5. If you get a black screen with a cursor blinking in the top left corner, simultaneously press Right-Ctrl and F1 again. This is because the login script switches to a different console, and will be improved in the future.

  6. Type
    cd ~/sage
    ./sage
    on the command line to start a shell interface in Sage.
  7. To work with files attached in a shared folder (if you have shared folders enabled), type
    attach /media/sf_<volume name>/filename
    in the Sage command line session.
  8. Press Right-Ctrl and F2 to return to the graphical Sage window.

6. Troubleshooting

7. Advanced Options

  • You can log into the virtual machine from the text-mode console. Press Right-Ctrl and F1 for a different tty. The user account running the Sage notebook server is called sage with password sage. The root account password is sage, too.

  • You can also log into the virtual machine via ssh to port 2222. For example, with the command-line ssh client you would type
    ssh -p 2222 localhost
    on the host computer to log into the virtual machine.
  • Advanced users may want to note that the sage user is in the sudoers file now. You can run any command with administrative rights by sudo <command>.

  • List available optional packages with the optional_packages() command and type install_package('exact package name') to install a package. You can do this from an input box in the notebook.

  • To upgrade between stable releases, you can type the following at the command prompt:
    [sage@localhost sage]$ sage -upgrade
    Running an upgrade will take a significant amount of time.

    This will merge your changes to the Sage library with the latest version of Sage and build everything.

    WARNING: This will use up more disk space and is not guaranteed to result in a working upgraded Sage installation.

7.1. Changing the keyboard layout

7.1.1. For the graphical web browser

The easiest way to use your keyboard layout of choice is to use the host browser and connect to the Sage server running at http://localhost:8000. However, if you want to permanently change the layout in the virtual machine browser, you can do this as follows:

  1. Log into the virtual machine as user gui. For example, you can log into the virtual machine from the text-mode console: Press Right-Ctrl and F1 for a different tty. The user account running the web browser is called gui with password sage. See the advanced options section for more details.

  2. Edit the gui user's .xinitrc file:

    sagevm login: gui
    Password: 
    Last login: Tue Jul 12 13:32:39 on tty9
    [gui@sagevm ~]# nano .xinitrc

    and add setxkbmap <keyboard-coutry-code> as the first line. The country code is usually the two-character country code, for example de, gb, fi, fr, ... To use the dvorak keyboard layout you would write

    setxkbmap dvorak

    The complete list is described in /usr/share/X11/xkb/rules/base.lst.

  3. Save: Press Ctrl-X to exit, y to save, Enter to save it under the previous name .xinitrc

  4. Reboot the virtual machine to switch to the new keyboard layout.

7.1.2. Manually changing the layout on the console

To temporarily change the keyboard layout (for example, French AZERTY), you can drop to the shell and run the command

sudo loadkeys azerty

To make this change permanent, you have to edit a configuration file. Run

sudo nano /etc/sysconfig/keyboard

and set it to the following:

KEYTABLE="fr-latin1"
MODEL="pc105+inet"
LAYOUT="fr"

7.2. Giving Others Access to the Sage Virtual Machine

You can run the Sage appliance as a server on the network, so that others can access it similar to http://www.sagenb.org. In this case, you have to make some changes to the virtual machine such that not everybody can log in.

  1. Log into the virtual machine as root: In the virtual machine, press Alt-F1, log in as user root with password sage. See the advanced options section for more details.

  2. Once you are logged in as root, change the password for the root, sage user (running the notebook server), and gui user (running the browser) account:

    [root@sage ~]# passwd root
    Changing password for user root.
    Retype new password: 
    passwd: all authentication tokens updated successfully.
    [root@sage ~]# passwd sage
    Changing password for user sage.
    Retype new password: 
    passwd: all authentication tokens updated successfully.
    [root@sage ~]# passwd gui
    Changing password for user gui.
    Retype new password: 
    passwd: all authentication tokens updated successfully.
  3. Now switch to the sage account. You can either log in as sage with the new password, or type
    [root@sage ~]# su sage
    [sage@sage root]$ cd
    [sage@sage ~]$
  4. Configure the notebook server to start in a secure mode. (These instructions are for versions previous to 5.4; some options changed at this time.) For this, you have to edit the .bash_profile file in the sage account. For example, type

    [sage@sage ~]$ nano .bash_profile
    and replace the line
    ./sage -notebook interface=\'\' port=8000 open_viewer=False require_login=False
    with
    ./sage -notebook interface=\'\' port=8000 open_viewer=False require_login=True secure=True

    Then press Ctrl X to exit, and y when nano asks you to save the file before exiting (save it again as .bash_profile).

  5. Now reboot the virtual appliance:
    [sage@sage ~]$ exit
    exit
    [root@sage ~]# reboot
  6. Upon the reboot, Sage will ask for some further information. You will find the following in the VirtualBox window:

    ----------------------------------------------------------------------
    | Sage Version ..., Release Date: ...                                |
    | Type notebook() for the GUI, and license() for information.        |
    ----------------------------------------------------------------------
    
    Please wait while the Sage Notebook server starts...
    ...
    notebook(interface=r'''''''',port=8000,open_viewer=False,require_login=True,secure=True)
    The notebook files are stored in: sage_notebook.sagenb
    In order to use an SECURE encrypted notebook, you must first run notebook.setup().
    Now running notebook.setup()
    Domain name [localhost]: 
    Simply press return to use the default domain name. A SSL cryptographic key is then automatic created with this hostname.
  7. Now set up an admin password for the Sage notebook server. Unless you have set up such an account previously, Sage will ask you for a password automatically:
    Please choose a new password for the Sage Notebook 'admin' user.
    Do _not_ choose a stupid password, since anybody who could guess your password
    and connect to your machine could access or delete your files.
    NOTE: Only the md5 hash of the password you type is stored by Sage.
    You can change your password by typing notebook(reset=True).
    
    Enter new password: 
    Please enter a new password following the instructions.
  8. Optional: Once your Sage server is secured, you can make it accessible from the network. For this, you have to stop the virtual machine (not just suspend it). Then, in the VirtualBox window, go to Settings -> Network -> Adapter 1. It does say Attached to: NAT. Switch it to Bridged Adapter. Click OK and restart the virtual machine. Note: This makes your virtual machine accessible from the network. Only perform this step after you have changed passwords and configured the notebook server to be secure, as described above.

  9. Optional: Give the Sage virtual machine more resources, so it can server more clients. Go to Settings -> System. On the Motherboard tab, increase Base Memory to about half of the physical ram of your host computer. On the Processor tab, increase the number of processors to your host CPU number of cores. Finally, on the Acceleration tab, enable VT-x/AMD-V if your CPU supports this.

To connect to the Sage server, you have to use https://... instead of http://.... For example, on the host computer where the virtual machine is running, the Sage server listens at https://localhost:8000. Since our SSL key is not signed by a certificate authority (which you can do, but it does cost money) web browsers will show a warning that the authority of the key cannot be verified. While a signed SSL key would provide a higher level of security, the network data between the browser and the Sage server is nevertheless encrypted.

7.3. How to become a Sage developer

Some Unix familiarity is assumed below. If you've never used anything but Windows, some of this won't make sense.

  1. Change to the $SAGE_ROOT directory:

    [sage@localhost directory]$ cd
    [sage@localhost ~]$ cd sage
    [sage@localhost sage]$ 
  2. To actually edit files, you'll perhaps want to install the editor of your choice. For example, to install Emacs do this:
    [sage@localhost sage]$ sudo yum install emacs
    The nano editor is included.
  3. Now type, for example,
    [sage@localhost sage]$ cd devel/sage/sage/rings/
    [sage@localhost rings]$ emacs arith.py
    or
    [sage@localhost rings]$ nano arith.py
    and edit the file to your heart's content.
  4. Save the file and type sage -br to build the changes and install them:

    [sage@localhost rings]$ cd
    [sage@localhost ~]$ cd sage
    [sage@localhost sage]$ sage -br
    ----------------------------------------------------------
    sage: Building and installing modified SAGE library files.
    ...
    ----------------------------------------------------------------------
    | SAGE Version x.y.z, Release Date: .........