Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Migrated to Confluence 5.3

...

Note that all Synapse resources should be created in US East, as Beanstalk is not yet available everywhere.

Table of Contents

Crowd (skip if using existing crowd deployment)

If necessary, the instructions are here:

[http://sagebionetworks.jira.com/wiki/display/PLFM/Setting+Up+Production+Crowd|http://sagebionetworks.jira.com/wiki/display/PLFM/Setting+Up+Production+Crowd]

Restarting Crowd

If the server goes down:

...

Tell the platform team what you are going to do

Really.  Make sure everyone has checked in what you think should be checked in for the release. Make sure Synapse customers have a heads up as well. Give yourself a bit of a buffer between when checkins are done and when you need to have the system cut over. 

Log what you do to AWS Platform account in the Log

Open an entry in the Platform AWS Log. It is helpful to think though exactly what you are going to do and write it down.  Then as you execute the change, if you deviate from the steps you wrote in the log, change the log.  In the end when you haven't made any mistakes and everything has gone smoothly you will think this was a waste of time.  It wasn't.  The closer you are to a big demo the more true this will be.

Crowd (skip if using existing crowd deployment)

In most cases you should be re-using existing Crowd instances. We currently have two crowd servers running:

prod: https://dev-crowd.sagebase.org:8443/crowd|/console

...

staging + test (shared): https://prod-crowd.sagebase.org:8443/crowd]
You should see Crowd log-in page.  If not then ssh in to crowd.sagebase.org  as ec2-user, using the standard key for 'platform' owned ec2 instances, PlatformKeyPairEast

At the unix prompt:
      ps -a

Should show one java process, if not
      cd /usr/local/atlassian-crowd-2.2.7/

     ./start_crowd.sh

Now verify that the log-in page appears in your web browser.

The above instructions apply to 'crowd-dev.sagebase.org' as well as 'crowd.sagebase.org'.

/console

If setting up a new Crowd server or for help troubleshooting see: Setting Up Production Crowd

If you just need to point a stack at a particular crowd instance, you do this by setting the org.sagebionetworks.crowd.endpoint in the stack.properties file (URLs as above minus the /crowd/console bit)

Get the build artifacts from Artifactory

You should not be deploying anything you built yourself on your local machine.  Only deploy build artifacts generated by Bamboo and stored in http://sagebionetworks.artifactoryonline.comArtifactory as the result of a clean build.  See http://sagebionetworks.jira.com/wiki/display/PLFM/Branching+and+TaggingBranching and Tagging for information about managing the build, branch, and tag process.  You   For a full upgrade you will need 3 .war files out of artifactory for a deployment: services-repository-<version>.war, services-authentication-<version>.war, and portal-<version>.war.  Each must go into its own Beanstalk environment. -

The specific steps are:

  1. log in to: http://sagebionetworks.artifactoryonline.com/http://sagebionetworks.artifactoryonline.com/
  2. Go to the Artifacts tab
      Go
      1. For a snapshot build go to: libs-snapshots-local > org > sagebionetworks > [project] > [version]- SNAPSHOT > [project][version]SNAPSHOT.war
      2. For a released version go to: libs-releases-local > org > sagebionetworks > [project] > [version
      ]-SNAPSHOT
      1. ] > [project][version].war-
    1. Click download
    2. Now log into the AWS console
    3. click on the "Elastic Beanstalk" tab
    4. Select the 'stack' (Synapse or Synapse-Staging)  Note that you will have to upload the .war file into each stack, or what Beanstalk calls an "Application"
    5. From here, you can either just upload the wars as new versions without deploying if you are going to build new environments, or upload and deploy in one step if your environments already exist.
    6. To update an environment in place
      1. A number of "Environments" will be listed.  Click on "Environment Details" for the environment of interest.
      2. Click on "Deploy a different version."
      3. Click the radio button "Upload and deploy a new version"
      4. To
      name
      1. label the
      .war
      1. version, follow the naming convention given here: http://sagebionetworks.jira.com/wiki/display/PLFM/Branching+and+Tagginghttp://sagebionetworks.jira.com/wiki/display/PLFM/Branching+and+Tagging
      2. Upload the .war file that you downloaded from Artifactory.
      3. Your new .war file will now be deployed to Elastic Beanstalk.
      4.  Repeat for additional war(s) that need upgrades, then skip ahead to verification
    7. Alternately, if you are going to build new environments, you can just upload the wars and label the new versions for later use.

    Create or Configure MySQL RDS Service (Skip this section if using existing Environments.)

    See Synapse Database Setup and Configuration for details on how to create a new schema for a new stack or instance.  The staging and production stacks use Amazon's RDS service.  Currently, both stacks use different databases in the same RDS instance.  The same RDS service also holds the ID Generator db, as well as data for Crowd.

    Create Beanstalk Environments (Skip this section if using existing Environments.)

    ...

    Create two more, so that there is one for Auth services, one for Repo services, and one for SynapseWeb

    Create Host Name

    Sign in to GoDaddy, select sagebase.org,  and launch Domain Manager. 

    Create synapse-prod (.sagebase.org) and point it to prod-synapseweb.elasticbeanstalk.com

    Ditto for auth-prod and reposvc-prod

    ...

    Configure

    ...

    See Synapse Database Setup for details on how to create a new schema for a new stack or instance.  The staging and production stacks use Amazon's RDS service.  Currently, both stacks use different databases in the same RDS instance.  The same RDS service also holds the ID Generator db, as well as data for Crowd.

    ...

    Environments

    The configuration of all environments for all Synapse components should be the same, with the exception that we leave port 80 on the web app load balancer open and closed everywhere else.

    Configure Server

    Click on 'edit configuration' in the Beanstalk UI, start on 'Server' tab:

    ...

    Custom AMI ID=ami-524db23b

    Configure Load Balancer

    Click on 'Load Balancer' tab

    For 'HTTP Listener port' choose 'OFF' for the repo and auth services, choose '80' for the portal.

    For 'HTTPS Listener port' choose '443'. 

    For 'SSL Cert' choose arn:aws:iam::325565585839:server-certificate/SynapseCert

    Configure Notifications

    Click on 'Notifications' tab

    Set Email Address to 'platform@sagebase.org'

    Configure Container

    Click on 'container.'

    In the JVM Command Line Options For a production deployment:

    ...

    This is the minimum information needed to bootstrap our system with the information needed to load a configuration via a .properties file.  Here, the actual .properties file should be loaded in S3 as described below

    Setting up a Properties file in S3 (Skip this section if using existing Environments.)

    For each stack, we have created a unique IAM User, encryption key, and configuration file.  These values are passed into the container of the environments as described above.  AWS access key ids, secret keys, encryption keys, and the url for an environment can be found on sodo at /work/platform/PasswordsAndCredentials/StackCredentials/IAMUsers in the appropriate .csv file.  All stack environments run under this IAM User, and have permission to access their configuration file from S3.  Configuration files can be loaded / updated in S3 under the elasticbeanstalk-us-east-1-325565585839 bucket (this is the same place the .war files are deployed).  This will give URLs of the form https://s3.amazonaws.com/elasticbeanstalk-us-east-1-325565585839/<stack-name><Instance-name>-stack.properties  If you are creating a new stack, you will have to create the IAM user and grant that user access to access the configuration file using the IAM tab of the AWS console.  In most cases you should be able to keep the configuration the file the same, or replace it with a new file of the same name.  Note that the stack and instance names embedded in the .properties file must match the names passed in to the environment via PARAM3 and PARAM4; this is a safety feature to reduce the risk of wiring the wrong property file to the wrong environment.

    Note that if you are setting up a .properties file, any field that is a password should be encryped.  You can encrypt strings by running StringEncrypter, passing in two arg's: (1) the string to be encoded, (2) the aforementioned encryption key.

    How to run the Data Loader

    Once environments are running, you can populate the system with a set of starting data.  On one of the local servers, goto /work/platform/DatasetMetadataLoader and execute the following:

    ...

    Migrate data from old stack (Skip this section if using existing Environments.)

    See the page on Repository Administration for instructions on how to backup and restore data from Synapse schemas.  To migrate data from one instance to another in a stack the current procedure is to take a back up of the old stack, shut the stack down, and then copy the data to the new stack.  Note there is a small risk of data changed in the old stack being lost if somebody adds something to the repository after the backup process has completed.  This will be addressed by PLFM-404      .  (Even if you shut down the Synapse web portal before you take the backup, changes can still come in via the repo API, which must be up to take the backup.)  In meantime, workaround by communicating with team members and our small user base.

    Update CNAMES (Skip this section if using existing Environments.)

    Sign in to GoDaddy, select sagebase.org,  and launch Domain Manager. We have defined public URLs for the various stacks and components, e.g. synapse-staging (.sagebase.org) for the web app, auth-staging for auth, etc.  Point these to the elastic beanstalk URL, which should be something of the form stackName-componentName.elasticbeanstalk.com.

    Once you have CNAMES pointed to the new stack, update stackInstance-stack.properties file, upload to S3, and restart the app servers to apply the change.  Having our components talk to each other via the public aliases avoids security exceptions.  See PLFM-506     .

    Deploy From Artifactory

    Create an IAM credentials file, using the platform credentials, per http://stackoverflow.com/questions/5396932/why-are-no-amazon-s3-authentication-handlers-ready

    The IAM key should be AWSAccessKeyId=AKIAINNFCDBA3NBOQO2Q

    Point to this file from the environment variable AWS_CREDENTIAL_FILE

    In trunk\tools\SynapseDeployer\main.py
    set the following
    - version = '0.8' # set to the actual version to be deployed
    - isSnapshot = True
    - beanstalk_application_name =
    set to 'Synapse-Staging' for staging, 'Synapse' for Synapse
    - componentsToUpgrade: set to the target stack, e.g. 'prod-b-auth' for stack 'b' of alpha/prod
    - make sure deploymentBucket=elasticbeanstalk-us-east-1-325565585839

    In the directory trunk\tools\SynapseDeployer, start the python interpreter, then type:

    Code Block
    
    import sys
    sys.path.append("boto-2.1.1")
    import main
    

    Verify Deployment

    To verify deployment, run top-level queries against the repository instances from an authenticated account.

    Make sure you can download the MSKCC clinical data layer from S3.

    TODO: Add queries and expected counts returned.

    Build and deploy R packages

    See R Package Builds for details of how to do this. You might ask Nicole to do this with you if you are new to it.

    See Managing R packages for how to install the lastest version on Belltown.

    Once the latest version in deployed to the CRAN server, you should upgrade the R Synapse client version on Belltown. An upgrade script is available in /work/platform/configuration/deployment/synapseRClient.

    Code Block
    cd /work/platform/configuration/deployment/synapseRClient
    sudo ./upgradeSynapseClient.sh

    Make sure to check the output for error messages.

    How to run the Phenotype Descriptions Loader

    Run this on the shared servers where the datasets live.

    For just one dataset:

    Code Block
    
    cd /work/platform/DatasetMetadataLoader
    ./clinicalVariableDescriptionsLoader.py -e https://repo-staging.sagebase.org/repo/v1 -a https://auth-staging.sagebase.org/auth/v1 \
    --user <platform_admin_email> --password <platform_admin_pw> \
    --layerId 3965 --descriptionFile /work/platform/source/sanger_cell_lines/phenotype/description.txt
    

    For all datasets it reads from AllDatasetLayers.csv:

    Code Block
    
    cd /work/platform/DatasetMetadataLoader
    ./clinicalVariableDescriptionsLoader.py -e https://repo-staging.sagebase.org/repo/v1 -a httphttps://<auth_instance>auth-staging.sagebase.org/auth/v1 \
    --uuser <platform_admin_email>  --ppassword <platform_admin_pw>
    

    This will create a publicly-accessible project called Sage BioCuration, and populate it with curated data from Sage's repository data team.

    If you need to repopulate the data in S3, pass the -3 argument to the data loader. It upload the data in serial right now so it takes an hour or two. We really should only need to do this if we've messed up our S3 bucket.

    Verify Deployment

    To verify deployment, run top-level queries against the repository instances from an authenticated account.

    Make sure you can download the MSKCC clinical data layer from S3.

    TODO: Add queries and expected counts returned.You can find the code for this script here clinicalVariableDescriptionsLoader.py