From 66c3ff1eac3b329ffca6725d806e77e3ed777841 Mon Sep 17 00:00:00 2001 From: Amy Paguirigan Date: Thu, 3 Mar 2022 09:54:11 -0800 Subject: [PATCH 1/4] allow for lack of aws creds --- README.md | 60 +++++--- cromUserConfig.txt | 6 +- cromwellv1.2.sh => cromwellv1.3.sh | 16 ++- fh-S3-cromwell.conf | 6 +- fh-cromwell.conf | 216 +++++++++++++++++++++++++++++ 5 files changed, 273 insertions(+), 31 deletions(-) rename cromwellv1.2.sh => cromwellv1.3.sh (65%) create mode 100755 fh-cromwell.conf diff --git a/README.md b/README.md index 44beb08..5fd6c9d 100644 --- a/README.md +++ b/README.md @@ -16,13 +16,15 @@ Amy also made a shiny app you can use to monitor your own Cromwell server workfl ## Steps to prepare If you have questions about these steps, feel free to contact Amy Paguirigan (`apaguiri`) or `scicomp`. -### Rhino Access +### Rhino Access (one time) Currently, to run your own Cromwell server you'll need to know how to connect to `rhino` at the Fred Hutch. If you have never used the local cluster (`rhino`/`gizmo`), you may need to file a ticket by emailing fredhutch email `scicomp` and requesting your account be set up. To do this you'll need to specify which PI you are sponsored by/work for. You also may want to read a bit more about the use of our cluster over at [SciWiki](https://sciwiki.fredhutch.org/) in the Scientific Computing section about Access Methods, and Technologies. -### AWS S3 Access -This setup requires that you have a set of AWS credentials for access to an AWS S3 bucket, and specifically to the S3 bucket(s) from which you pull workflow inputs. Refer to [SciWiki](https://sciwiki.fredhutch.org/scicomputing/compute_cloud/#get-aws-credentials) or email `scicomp` to request credentials. +### AWS S3 Access (optional as of version 1.3) +Prior to release 1.3, this setup required that you have a set of AWS credentials for access to an AWS S3 bucket, and specifically to the S3 bucket(s) from which you pull workflow inputs. Refer to [SciWiki](https://sciwiki.fredhutch.org/scicomputing/compute_cloud/#get-aws-credentials) or email `scicomp` to request credentials. -### Database Setup +As of version 1.3 if you have credentials, then the Cromwell server will be configured to allow input files to directly specified using their AWS S3 url. However if you do not have AWS credentials, then the server will now successfully start up, simply without the ability to localize files from S3, thus all test workflows that use files in S3 will not work for you, but everything else should. + +### Database Setup (one time) These instructions let you stand up a Cromwell server for 7 days at a time. If you have workflows that run longer than that or you want to be able to get metadata for or restart jobs even after the server goes down, you'll want an external database to keep track of your progress even if your server goes down (for whatever reason). It also will allow your future workflows to use cached copies of data when the exact task has already been done (and recorded in the database). We have found as well that by using a MySQL database for your Cromwell server, it will run faster and be better able to handle simultaneous workflows while also making all the metadata available to you during and after the run. We currently suggest you go to [DB4Sci](https://mydb.fredhutch.org/login) and see the Wiki entry for DB4Sci [here](https://sciwiki.fredhutch.org/scicomputing/store_databases/#db4sci--previously-mydb). There, you will login using Fred Hutch credentials, choose `Create DB Container`, and choose the MariaDB option. The default database container values are typically fine, EXCEPT you likely need either weekly or no backups (no backups preferred) for this database. Save the `DB/Container Name`, `DB Username` and `DB Password` as you will need them for the configuration step. Once you click submit, a confirmation screen will appear (hopefully), and you'll need to note which `Port` is specified. This is a 5 digit number currently. @@ -45,7 +47,7 @@ MariaDB [(none)]> exit ## Server setup instructions -1. Decide where you want to keep your Cromwell configuration files. This must be a place where `rhino` can access them, such as in your `Home` directory, which is typically the default directory when you connect to the `rhinos`. Create a `cromwell-home` folder (or whatever you want to call it) and follow these git instructions to clone it directly. +1. Decide where you want to keep your Cromwell configuration files. This must be a place where `rhino` can access them, such as in your `Home` directory, which is typically the default directory when you connect to the `rhinos`. We suggest you create a `cromwell-home` folder (or whatever you want to call it) and follow these git instructions to clone it directly. 2. First set up the customizations per user that you're going to want for your server(s) by making user configuration file(s) in your `cromwell-home` or wherever you find convenient. You can manage mulitple Cromwell profiles this way by just maintaining different files full of credentials and configuration variables that you want. @@ -96,10 +98,24 @@ Go have fun now. ``` > NOTE: Please write down the node and port it specifies here. This is the only place where you will be able to find the particular node/port for this instance of your Cromwell server, and you'll need that to be able to send jobs to the Crowmell server. If you forget it, `scancel` the Cromwell server job and start a new one. -6. For using the API (via a browser, some other method of submission), you'll want to keep the node and port number it tells you when you start up a fresh Cromwell server. When you go your browser, you can go to (for example) `http://gizmok30:2020` ("2020" or whatever the webservice port it told you) to use the Swagger UI to submit workflows. This node host and port also is what you use to submit and monitor workflows with the Shiny app at [cromwellapp.fredhutch.org](https://cromwellapp.fredhutch.org/) where it says "Current Cromwell host:port", you put `gizmok30:2020`. +6. This node host and port is what you use to submit and monitor workflows with the Shiny app at [cromwellapp.fredhutch.org](https://cromwellapp.fredhutch.org/). After you click the "Connect to Server" button, you'll put `gizmok30:2020` (or whatever your node:port is) where it says "Current Cromwell host:port". + +7. While your server will normally stop after 7 days (the default), at which point if you have jobs still running you can simply restart your server and it will reconnect to existing jobs/workflows. However, if you need to take down your server for whatever reason before that point, you can go to `rhino` and do: + +``` +# Here `username` is your Fred Hutch username +squeue -u username +## Or if you want to get fancy: +squeue -o '%.18i %.9P %j %.8T %.10M %.9l %.6C %R' -u username + +## You'll see a jobname "cromwellServer". Next to that will be a JOBID. In this example the JOBID of the server is 50062886. + +scancel 50062886 -7. See our [Test Workflow folder](https://github.com/FredHutch/diy-cromwell-server/tree/main/testWorkflows) once your server is up and run through the tests specified in the markdown there. +``` + +8. See our [Test Workflow folder](https://github.com/FredHutch/diy-cromwell-server/tree/main/testWorkflows) once your server is up and run through the tests specified in the markdown there. > NOTE: For those test workflows that use Docker containers, know that the first time you run them, you may notice that jobs aren't being sent very quickly. That is because for our cluster, we need to convert those Docker containers to something that can be run by Singularity. The first time a Docker container is used, it must be converted, but in the future Cromwell will used the cached version of the Docker container and jobs will be submitted more quickly. ## Guidance and Support @@ -129,11 +145,6 @@ SCRATCHDIR=/fh/scratch/delete90/... ### Suggestion: /fh/fast/pilastname_f/cromwell/workflow-logs WORKFLOWLOGDIR=~/cromwell-home/workflow-logs -## Where do you want final output files specified by workflows to be copied for your subsequent use? -## Note: this is a default for the server and can be overwritten for a given workflow in workflow-options. -### Suggestion: /fh/fast/pilastname_f/cromwell/outputs -WORKFLOWOUTPUTSDIR=/fh/scratch/delete90/... - ## Where do you want to save Cromwell server logs for troubleshooting Cromwell itself? ### Suggestion: ~/home/username/cromwell-home/server-logs SERVERLOGDIR=~./cromwell-home/server-logs @@ -146,21 +157,32 @@ CROMWELLDBNAME=... CROMWELLDBUSERNAME=... CROMWELLDBPASSWORD=... +## Number of cores for your Cromwell server itself - usually 4 is sufficient. +###Increase if you want to run many, complex workflows simultaneously or notice your server is slowing down. NCORES=4 +## Length of time you want the server to run for. +### Note: when servers go down, all jobs they'd sent will continue. When you start up a server the next time +### using the same database, the new server will pick up whereever the previous workflows left off. "7-0" is 7 days, zero hours. +SERVERTIME="7-0" ``` -Whether these customizations are done user-by-user or lab-by-lab depend on how your group wants to interact with workflows and data. Also, as there are additional features provided in the additional config's we provide, there may be additional customization parameters that you'll need. Check the config directories to see if there are additional copies of those files and associated server shell scripts. If they are absent that means you can use the base setup. Contact Amy Paguirigan about these issues for some advice. + +Contact Amy Paguirigan about these issues for some advice or file an issue on this repo. ## Task Defaults and Runtime Variables available For the gizmo backend, the following runtime variables are available that are customized to our configuration. What is specified below is the current default as written, you can edit these in the config file if you'd like OR you can specify these variables in your `runtime` block in each task to change only the variables you want to change from the default for that particular task. -- `Int cpu = 1` +- `cpu = 1` - An integer number of cpus you want for the task -- `String walltime = "18:00:00"` +- `walltime = "18:00:00"` - A string of date/time that specifies how many hours/days you want to request for the task -- `Int memory = 2000` +- `memory = 2000` - An integer number of MB of memory you want to use for the task -- `String partition = "campus-new"` - - Which partition you want to use, currently the only Bionic option is `campus-new` -- `String modules = ""` +- `partition = "campus-new"` + - Which partition you want to use, the default is `campus-new` but whatever is in the runtime block of your WDL will overrride this. +- `modules = ""` - A space-separated list of the environment modules you'd like to have loaded (in that order) prior to running the task. +- `docker = "ubuntu:latest"` + - A specific Docker container to use for the task. For the custom Hutch configuration, docker containers can be specified and the necessary conversions (to Singularity) will be performed by Cromwell (not the user). Note: when docker is used, soft links cannot be used in our filesystem, so workflows using very large datasets may run slightly slower due to the need for Cromwell to copy files rather than link to them. +- `dockerSL= "ubuntu:latest"` + - This is a custom configuration for the Hutch that allows users to use docker and softlinks only to specific locations in Scratch. It is helpful when working with very large files. diff --git a/cromUserConfig.txt b/cromUserConfig.txt index 83df417..abcd6cd 100755 --- a/cromUserConfig.txt +++ b/cromUserConfig.txt @@ -8,10 +8,6 @@ SCRATCHDIR=/fh/scratch/delete90/... ### Suggestion: /fh/fast/pilastname_f/cromwell/workflow-logs WORKFLOWLOGDIR=~/cromwell-home/workflow-logs -## Where do you want final output files specified by workflows to be copied for your subsequent use? -## Note: this is a default for the server and can be overwritten for a given workflow in workflow-options. -### Suggestion: /fh/fast/pilastname_f/cromwell/outputs -WORKFLOWOUTPUTSDIR=/fh/scratch/delete90/... ## Where do you want to save Cromwell server logs for troubleshooting Cromwell itself? ### Suggestion: ~/home/username/cromwell-home/server-logs @@ -26,7 +22,7 @@ CROMWELLDBUSERNAME=... CROMWELLDBPASSWORD=... ## Number of cores for your Cromwell server itself - usually 4 is sufficient. -###Increase if you want to run many, complex workflows simlutaneously or notice your server is slowing down. +###Increase if you want to run many, complex workflows simultaneously or notice your server is slowing down. NCORES=4 ## Length of time you want the server to run for. ### Note: when servers go down, all jobs they'd sent will continue. When you start up a server the next time diff --git a/cromwellv1.2.sh b/cromwellv1.3.sh similarity index 65% rename from cromwellv1.2.sh rename to cromwellv1.3.sh index c6f60b1..51d155a 100755 --- a/cromwellv1.2.sh +++ b/cromwellv1.3.sh @@ -17,7 +17,7 @@ fi echo "Getting an updated copy of Cromwell configs from GitHub..." # If the repo already exists, delete it then re-clone a fresh copy if [ -d "diy-cromwell-server" ]; then rm -Rf diy-cromwell-server; fi -git clone --branch v1.2 https://github.com/FredHutch/diy-cromwell-server.git +git clone --branch v1.3 https://github.com/FredHutch/diy-cromwell-server.git --quiet echo "Setting up all required directories..." # If the directory to write server logs to doesn't yet exist, make it. @@ -25,11 +25,23 @@ if [ ! -d $SERVERLOGDIR ]; then mkdir -p $SERVERLOGDIR fi +# If the user doesn't have AWS credentials then the AWS-naive Cromwell config file needs to be used. +# Note this doesn't check that if the aws credentials exist that they are valid - that occurs when jobs using AWS get created in a workflow. +echo "Detecting existence of AWS credentials..." +if [ -f "~/.aws/credentials" ] +then + echo "Credentials found, setting appropriate configuration..." + CONFFILE="./diy-cromwell-server/fh-S3-cromwell.conf" +else + echo "Credentials not found, setting appropriate configuration..." + CONFFILE="./diy-cromwell-server/fh-cromwell.conf" +fi + echo "Requesting resources from SLURM for your server..." # Submit the server job, and tell it to send netcat info back to port 6000 sbatch --export=MYPORT=6000 --cpus-per-task=$NCORES -N 1 --time=$SERVERTIME --job-name="cromwellServer" \ --output=$SERVERLOGDIR/cromwell_%A.out\ - ./diy-cromwell-server/cromwellServer.sh ./diy-cromwell-server/fh-S3-cromwell.conf \ + ./diy-cromwell-server/cromwellServer.sh $CONFFILE \ ${1} nc -l -p 6000 diff --git a/fh-S3-cromwell.conf b/fh-S3-cromwell.conf index 6989d89..52de8ad 100755 --- a/fh-S3-cromwell.conf +++ b/fh-S3-cromwell.conf @@ -61,11 +61,7 @@ aws { } engine { filesystems { - local { - localization: [ - "soft-link", "copy" # See SLURM backend for definitions. - ] - } + local {localization: ["soft-link", "copy" ]} s3 { auth = "default" } } } diff --git a/fh-cromwell.conf b/fh-cromwell.conf new file mode 100755 index 0000000..218ab63 --- /dev/null +++ b/fh-cromwell.conf @@ -0,0 +1,216 @@ +include required(classpath("application")) +services { MetadataService { + class = "cromwell.services.metadata.impl.MetadataServiceActor" + config { metadata-read-row-number-safety-threshold = 2000000 } } } + +database { + profile = "slick.jdbc.MySQLProfile$" + db { + driver = "com.mysql.cj.jdbc.Driver" + connectionTimeout = 5000 + } +} +webservice { + binding-timeout = 10s +} +workflow-heartbeats { + heartbeat-interval: 2 minutes + ttl: 10 minutes + write-failure-shutdown-duration: 5 minutes + write-batch-size: 10000 + write-threshold: 10000 +} +system { + file-hash-cache = true + input-read-limits { + tsv = 1073741823 + object = 1073741823 + string = 1073741823 + lines = 1073741823 + json = 1073741823 + } + io { + number-of-requests = 100000 + per = 5 seconds # normally 100 seconds + number-of-attempts = 10 + } +} +workflow-options { + # save all workflow logs to refer back to + workflow-log-temporary = false +} +akka.http.server.request-timeout = 60s +call-caching { + + # Allows re-use of existing results for jobs you've already run (default: + # false) + + enabled = true + + # Whether to invalidate a cache result forever if we cannot reuse them. + # Disable this if you expect some cache copies to fail for external reasons + # which should not invalidate the cache (e.g. auth differences between + # users): (default: true) + + invalidate-bad-cache-results = true +} + +engine { + filesystems { + local {localization: ["soft-link", "copy" ]} + } + } + +# Backend and filesystem +backend { + default = "gizmo" + providers { + gizmo { + actor-factory = "cromwell.backend.impl.sfs.config.ConfigBackendLifecycleActorFactory" + config { + glob-link-command = "ln -sL GLOB_PATTERN GLOB_DIRECTORY" + # For BeeGFS so softlink is used instead of hardlink + concurrent-job-limit = 5000 + runtime-attributes = """ + Int cpu = 1 + String? walltime + Int memory_mb = 2000 + String partition = "campus-new" + String? docker + String? modules = "" + String? dockerSL + """ + + submit = """ + set -e + source /app/lmod/lmod/init/bash + module use /app/modules/all + module purge + + if [ ! -z '${dockerSL}' ]; then + + # Ensure singularity is loaded if it's installed as a module + module load Singularity/3.5.3 + # Build the Docker image into a singularity image + DOCKER_NAME=$(sed -e 's/[^A-Za-z0-9._-]/_/g' <<< ${dockerSL}) + # The image will live together with all the other images to force caching of the .sif files themselves - note, always use docker hub tags!!! + IMAGE=$SINGULARITYCACHEDIR/$DOCKER_NAME.sif + + echo $DOCKER_NAME + echo $IMAGE + echo $SINGULARITYCACHEDIR + echo $SCRATCHPATH + + if [ ! -f $IMAGE ]; then # If we already have the image, skip everything + singularity pull $IMAGE docker://${dockerSL} + fi + + # Submit the script to SLURM + sbatch \ + --partition=${partition} \ + -J ${job_name} \ + -D ${cwd} \ + -o ${cwd}/execution/stdout \ + -e ${cwd}/execution/stderr \ + --cpus-per-task=${cpu} ${"--time=" + walltime} \ + --wrap "singularity exec --bind $SCRATCHPATH $IMAGE ${job_shell} ${script}" + + else + module load ${modules} + + sbatch \ + --partition=${partition} \ + -J ${job_name} \ + -D ${cwd} \ + -o ${out} \ + -e ${err} \ + --cpus-per-task=${cpu} ${"--time=" + walltime} \ + --wrap "/bin/bash ${script}" + fi + """ + submit-docker = """ + set -e + source /app/lmod/lmod/init/bash + module use /app/modules/all + module purge + + # Ensure singularity is loaded if it's installed as a module + module load Singularity/3.5.3 + + # Build the Docker image into a singularity image + DOCKER_NAME=$(sed -e 's/[^A-Za-z0-9._-]/_/g' <<< ${docker}) + + # The image will live together with all the other images to force + # "caching" of the .sif files themselves - note, always use docker + # hub tags!!! + IMAGE=$SINGULARITYCACHEDIR/$DOCKER_NAME.sif + + if [ -z $SINGULARITYCACHEDIR ]; + then + CACHE_DIR=$HOME/.singularity/cache + else + CACHE_DIR=$SINGULARITYCACHEDIR + fi + + LOCK_FILE=$CACHE_DIR/singularity_pull_flock + flock --verbose --exclusive --timeout 900 $LOCK_FILE \ + singularity exec --containall docker://${docker} echo "succesfully pulled ${docker}!" + + # Submit the script to SLURM + sbatch \ + --partition=${partition} \ + -J ${job_name} \ + -D ${cwd} \ + -o ${cwd}/execution/stdout \ + -e ${cwd}/execution/stderr \ + --cpus-per-task=${cpu} ${"--time=" + walltime} \ + --wrap "singularity exec --bind ${cwd}:${docker_cwd} --bind $HOME $IMAGE ${job_shell} ${docker_script}" + """ + filesystems { + local { + localization: [ + ## for local SLURM, hardlink doesn't work. Options for this and caching: , "soft-link" , "hard-link", "copy" + "soft-link", "copy" + ] + ## call caching config relating to the filesystem side + caching { + # When copying a cached result, what type of file duplication should occur. Attempted in the order listed below: "hard-link", "soft-link", "copy", "cached-copy". + duplication-strategy: [ + "soft-link", "copy" + ] + #cached-copy An experimental feature. This copies files to a file cache in + # /cached-inputs and then hard links them in the /inputs + # directory. cached-copy is intended for a shared filesystem that runs on multiple + # physical disks, where docker containers are used. Hard-links don't work between + # different physical disks and soft-links don't work with docker. + # Copying uses a lot of space if a multitude of tasks use the same input. + # cached-copy copies the file only once to the physical disk containing the + # and then uses hard links for every task that needs the input file. This can save a lot of space. + + # Possible values: md5, xxh64, fingerprint, path, path+modtime + # For extended explanation check: https://cromwell.readthedocs.io/en/stable/Configuring/#call-caching + # "md5" will compute an md5 hash of the file content. + # "xxh64" will compute an xxh64 hash of the file content. Much faster than md5 + # "fingerprint" will take last modified time, size and hash the first 10 mb with xxh64 to create a file fingerprint. + # This strategy will only be effective if the duplication-strategy (above) is set to "hard-link", as copying changes the last modified time. + # "path" will compute an md5 hash of the file path. This strategy will only be effective if the duplication-strategy (above) is set to "soft-link", + # in order to allow for the original file path to be hashed. + # "path+modtime" will compute an md5 hash of the file path and the last modified time. The same conditions as for "path" apply here. + # Default: "md5" + hashing-strategy: "path+modtime" + + # When true, will check if a sibling file with the same name and the .md5 extension exists, and if it does, use the content of this file as a hash. + # If false or the md5 does not exist, will proceed with the above-defined hashing strategy. + # Default: false + check-sibling-md5: false + } + } + } + kill = "scancel ${job_id}" + kill-docker = "scancel ${job_id}" + check-alive = "squeue -j ${job_id}" + job-id-regex = "Submitted batch job (\\d+).*" + } + } + } +} From 4df6c27df7ebeab319eefd555f9e47b0b16a2243 Mon Sep 17 00:00:00 2001 From: Amy Paguirigan Date: Thu, 3 Mar 2022 10:03:44 -0800 Subject: [PATCH 2/4] unquote --- README.md | 14 +++++--------- cromwellv1.3.sh | 4 ++-- 2 files changed, 7 insertions(+), 11 deletions(-) diff --git a/README.md b/README.md index 5fd6c9d..a853181 100644 --- a/README.md +++ b/README.md @@ -82,17 +82,13 @@ chmod +x cromwellv1.2.sh 5. Much like the `grabnode` command you may have used previously, the script will run and print back to the console instructions once the resources have been provisioned for the server. You should see something like this: ``` Your configuration details have been found... -Getting an updated copy of Crowmell configs from GitHub... -Cloning into 'tg-cromwell-server'... -remote: Enumerating objects: 196, done. -remote: Counting objects: 100% (196/196), done. -remote: Compressing objects: 100% (179/179), done. -remote: Total 196 (delta 96), reused 109 (delta 13), pack-reused 0 -Receiving objects: 100% (196/196), 41.14 KiB | 533.00 KiB/s, done. -Resolving deltas: 100% (96/96), done. +Getting an updated copy of Cromwell configs from GitHub... Setting up all required directories... +Detecting existence of AWS credentials... +Credentials found, setting appropriate configuration... Requesting resources from SLURM for your server... -Submitted batch job 36391382 +Submitted batch job 50205062 + Your Cromwell server is attempting to start up on **node/port gizmok30:2020**. If you encounter errors, you may want to check your server logs at /home/username/cromwell-home/server-logs to see if Cromwell was unable to start up. Go have fun now. ``` diff --git a/cromwellv1.3.sh b/cromwellv1.3.sh index 51d155a..557d27c 100755 --- a/cromwellv1.3.sh +++ b/cromwellv1.3.sh @@ -4,7 +4,7 @@ if [ ! -f ${1} ]; then exit fi source ${1} -if [[ -z $NCORES || -z $SCRATCHDIR || -z $WORKFLOWLOGDIR || -z $WORKFLOWOUTPUTSDIR || -z $SERVERLOGDIR || -z $CROMWELLDBPORT || -z $CROMWELLDBNAME || -z $CROMWELLDBUSERNAME || -z $CROMWELLDBPASSWORD ]]; then +if [[ -z $NCORES || -z $SCRATCHDIR || -z $WORKFLOWLOGDIR || -z $SERVERLOGDIR || -z $CROMWELLDBPORT || -z $CROMWELLDBNAME || -z $CROMWELLDBUSERNAME || -z $CROMWELLDBPASSWORD ]]; then echo "One or more of your personal configuration variables is unset, please check your configuration file and try again." exit 1 fi @@ -28,7 +28,7 @@ fi # If the user doesn't have AWS credentials then the AWS-naive Cromwell config file needs to be used. # Note this doesn't check that if the aws credentials exist that they are valid - that occurs when jobs using AWS get created in a workflow. echo "Detecting existence of AWS credentials..." -if [ -f "~/.aws/credentials" ] +if [ -f ~/.aws/credentials ] then echo "Credentials found, setting appropriate configuration..." CONFFILE="./diy-cromwell-server/fh-S3-cromwell.conf" From 7a7a71c6dd05ada86e49baa65e247b39ad283255 Mon Sep 17 00:00:00 2001 From: Amy Paguirigan Date: Thu, 3 Mar 2022 10:05:59 -0800 Subject: [PATCH 3/4] readme looks complete too --- README.md | 1 - 1 file changed, 1 deletion(-) diff --git a/README.md b/README.md index a853181..acc0c79 100644 --- a/README.md +++ b/README.md @@ -88,7 +88,6 @@ Detecting existence of AWS credentials... Credentials found, setting appropriate configuration... Requesting resources from SLURM for your server... Submitted batch job 50205062 - Your Cromwell server is attempting to start up on **node/port gizmok30:2020**. If you encounter errors, you may want to check your server logs at /home/username/cromwell-home/server-logs to see if Cromwell was unable to start up. Go have fun now. ``` From 32f578a0d301d950068f35264a076239a959aaec Mon Sep 17 00:00:00 2001 From: Amy Paguirigan Date: Thu, 3 Mar 2022 10:14:28 -0800 Subject: [PATCH 4/4] update contact info --- README.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/README.md b/README.md index acc0c79..8772648 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,5 @@ # diy-cromwell-server -A repo containing instructions for running a Cromwell server on `gizmo` at the Fred Hutch. These instructions were created and tested by Amy Paguirigan, so drop her a line if they don't work for you or you need help. Fred Hutch username is `apaguiri`. -Alternatively, join the discussion in The Coop Slack in the [#question-and-answer channel](https://fhbig.slack.com/archives/CD3HGJHJT) using your Fred Hutch, UW, SCHARP or Sagebase email. +A repo containing instructions for running a Cromwell server on `gizmo` at the Fred Hutch. These instructions were created and tested by Amy Paguirigan, so drop her a line if they don't work for you or you need help (Fred Hutch username is `apaguiri`) or you can tag @vortexing in Issues filed here in the GitHub repository. Note if you do this, please be sure that you do not post sensitive information in your troubleshooting information like passwords and such, but the more info you can provide about errors, the better. Alternatively, join the discussion in the Fred Hutch Bioinformatics and Computational Research Community Slack in the [#question-and-answer channel](https://fhbig.slack.com/archives/CD3HGJHJT) using your Fred Hutch, UW, SCHARP or Sagebase email. ## Cromwell Resources