- Get git here: https://git-scm.com/downloads
For access to GitHub and Hackathon Servers, you'll need an ssh key.
Data | Location |
---|---|
SRA Realign Objects | /data/realign/ or gs://ncbi_sra_realign/ |
Contig FASTAs | /data/testset_contigs/ or gs://ncbi_sra_contigs/ |
BLAST DBs | /blast/blastdb/ |
BigQuery Tables | project: strides-sra-hackathon-ops table: ncbi_sra_realign.hackathon_data project: strides-sra-hackathon-data table: various, see 4a TODO: below |
Server information | Refer to the pinned post Slack (#help-desk channel) |
Additional Tools | gs://ncbi_hackathon_aux_tools/ |
For reference use only -- should not be included in an external docker
-
Search data pre-indexed by NCBI
-
Query format:
bq --project_id strides-sra-hackathon-ops query --nouse_legacy_sql
In some case you may need to use
strides-sra-hackathon-data
, more on this below
-
-
Useful options:
bq --max_rows=100 --format=pretty --project_id strides-sra-hackathon-ops query --nouse_legacy_sql "<your_standard_sql_query_here" ```
The format flag also takes “json” and “csv” as valid arguments
- Available data:
bq show --schema --format=prettyjson strides-sra-hackathon-ops:ncbi_sra_realign.hackathon_data
Format also accepts “json”
-
Example query: to get a list of library selection strategies used by included SRRs:
bq --format=csv --project_id strides-sra-hackathon-ops query --nouse_legacy_sql "select distinct library_selection from ncbi_sra_realign.hackathon_data"
-
Expected Output:**
Waiting on bqjob_r2257ca5f589030fa_000001681a2c36ac_1 ... (0s) Current status: DONE library_selection RANDOM PCR RANDOM size fractionation MDA other unspecified MSLL Restriction Digest DNase Hybrid Selection ChIP RT-PCR Reduced Representation MBD2 protein methyl-CpG binding domain**
Note: Only the k-mer-based taxa with the most number of hits is reported, and only the blast hit with the highest bitscore is reported. Thus, most SRR+Contig pairs are unique, but some still appear more than once if there is a tie for kmer hits and/or blast bitscore (in these cases, the specific combination of blast hit and kmer hit isn’t meaningful)
- If you need to see all the kmer hits or blast hits use project
strides-sra-hackathon-data
and tablencbi_sra_realign.taxonomy
orncbi_sra_realign.viralblast
Contigs without any blast hits are not included in this table
-
If you would like to compare against a complete list of contigs please use project
strides-sra-hackathon-data
and tablencbi_sra_realign.coverage
. -
If you have a complex query you are interested in, especially if you think it might involve tables in
strides-sra-hackathon-data
, please let us know if we can help in the TODO:#help-desk
Slack Channel.
-
gsutil
is a collection of command line tools to access and modify data stored in google storage buckets.gsutil
Documentation Link -
gsutil
Examples:-
List files:
gsutil ls -l
gs://ncbi_sra_realign/SRR11587*.realign
-
Copy a file from the realign bucket to the current directory:
gsutil cp gs://ncbi_sra_realign/SRR1158703.realign .
-
Stream a file:
gsutil cat gs://ncbi_sra_realign/SRR1158703.coverage | less
-
Copy multiple files from the realign bucket:
gsutil -m cp gs://ncbi_sra_realign/SRR11587\*.realign .
-
Tip: To copy data between servers,
- use gsutil to copy from the source server to google storage first, then copy to the destination.
- or, add your ssh keys to the source server and use
scp localfile username@REMOTE-IP:/foo/bar/
-
Check your service account and project:
gcloud info
-
Pub/sub queue:
-
Create a topic:
gcloud pubsub topics create test1
-
Create a subscription to the topic:
gcloud pubsub subscriptions create --topic test1 sub1
-
Publish a message to the topic:
gcloud pubsub topics publish test1 --message qwe
-
Pull a message from the subscription:
gcloud pubsub subscriptions pull sub1
-
For server access, create an SSH key using ssh-keygen -t rsa -b 4096 -C "[email protected]"
, then post the public key in the`#public_keys' slack channel.
Server IP information is listed in the #help-desk
channel in slack (pinned message).
For most servers, access them using ssh [email protected]
where your-email
is the name part of the email address you used when generating your SSH key, and 1.2.3.4
is the IP address of the server
-
A quick way to verify access is to use the command
ssh [email protected] whoami
- this will echo back your username if successful. -
If you have trouble connecting, check the username, and try first with a simple command-line
ssh
client.
Several solr and other database servers are available.
- For Solr: URL Access: http://IP-ADDRESS:7790/solr/#/ (requires browser authentication).
See the pinned post in the
#help-desk
channel in slack for server IP addresses. Contact a friendly admin for username or password information.
-
Solr is installed as a docker image
solr01
.- Copy files to the image using
docker cp localfile solr01:/path/
- Restart solr using
sudo docker container restart solr01
- Copy files to the image using
-
Example solr API Query using
curl
$ curl -u USERNAME:PASSWORD "IP-ADDRESS:7790/solr/tstcol01/select?q=\*:\*"
Response:
{ "responseHeader":{ "Status":0, "QTime":0, "Params":{ "q":"\*:\*"}}, "response":{"numFound":0,"start":0,"docs":\[\] }}
-
Data Import (all on one line)
curl -u USERNAME:PASSWORD "IP-ADDRESS:7790/solr/tstcol01/update/json/docs?commit=true" -X POST -H 'Content-Type:application/json' --data-binary "FULL_PATH_TO_DATA.json"
For example:
curl -u USERNAME:PASSWORD "IP-ADDRESS:7790/solr/tstcol01/update/json/docs?commit=true" -X POST -H 'Content-Type:application/json' --data-binary test_known4.json
Where test_known4.json contains:
[{"hit_id" : 1, "Contig" : "SRR123.contig.1", "method" : "mmseq2", "parameters" : "some parameters", "accession": "AC12345.1", "simil":0.8},** {"hit_id" : 2, "Contig" : "SRR123.contig.1", "method" : "rpstblastn", "parameters" : "some parameters", "accession": "AC12345.1", "simil":0.8}, {"hit_id" : 3, "Contig" : "SRR123.contig.2", "method" : "mmseq2", "parameters" : "some parameters", "accession": "AC12356.2", "simil":0.9}, {"hit_id" : 4, "Contig" : "SRR123.contig.2", "method" : "rpstblastn", "parameters" : "some parameters", "accession": "AC12345.1", "simil":0.4}, git {"hit_id" : 5, "Contig" : "SRR123.contig.1", "method" : "AC12356.2", "parameters" : "this is some parameters", "accession": "AC12345.1", "simil":0.5} ]
-
Realigned metagenomic SRA runs are located in the ncbi_sra_realign
bucket. To access them directly please refer to gsutil.
The bucket with realigned runs should be mounted on the VMs during the main hackathon event under the directory /data/realign/
. Realign files are named based on their corresponding SRA run accession number, for example /data/realign/SRR1158703.realign
Realign objects are effectively the same reads (bases) as the original SRA runs but aligned onto host (human) and either viral contigs or references and onto denovo contigs assembled with skesa.
-
For example,
SRR649927.realign
contains 964 reads mapped onto human, 9043281 reads mapped onto denovo contigs and 1392735 unmapped reads:bq --maxrows=10000 --projectid strides-sra-hackathon-data query 'select * from ncbisrarealign.summary where accession="SRR649927"'
-
To check taxonomy of the contigs:
bq --projectid strides-sra-hackathon-data query 'select * from ncbisrarealign.taxonomy where accession="SRR649927"'`
-
To extract contigs from a realign object:
dump-ref-fasta --localref SRR649927.realign > SRR649927.contigs.fa
-
Human references GRCh38.p12 was used to align reads before assembling the rest. Please find the full list of sequences here: https://www.ncbi.nlm.nih.gov/assembly?term=GRCh38&cmd=DetailsSearch
-
There are 2 types of contigs in realign objects: guided and denovo. Guided contigs have been built with guided assembler using a predefined viral reference set. These are almost 300 sequences including multiple Influenza serotypes, Herpes, Ebola etc.
The names of guided contigscan be filtered based on regex:
grep -P '^(?\!Contig)\[A-Z0-9.\]+_\\d+$'
Contig names are based on reference sequence accession
used as a guide. For example contig named KF021598.1_1
has been built using KF021598.1
as a guide reference.
Denovo contigs have been assembled with skesa after filtering out human and viral reads. Their names start with Contig prefix.
Contig names are unique only within a realign object, not across realign objects.
(Already installed on pre-built hackathon VM instances)
Download from https://www.ncbi.nlm.nih.gov/sra/docs/toolkitsoft/
Or, copy the pre-release version from google storage:
gsutil cp gs://ncbi_hackathon_aux_tools/sratoolkit.2.9.4.pre.tar.gz .
- Examples:
- Lookup by accession:
srapath <accession>
- Download and cache run locally:
prefetch <accession>
- Get statistics:
sra-stat --quick --xml <accession>
- Dump reads into separate fastq files:
fastq-dump --split-files --split-spot <accession>
- Extract contigs (local sequences):
dump-ref-fasta -l <accession>
- Convert an SRA object to BAM:
sam-dump --unaligned <accession> | samtools view -Sb -<accession>.bam
- Lookup by accession:
Instructions on running the dockerized BLAST are at https://github.com/ncbi/docker/blob/master/blast/README.md
Make sure the BLAST_DIR env variable is set before you try the commands.
For a complete list of command-line blast arguments see: https://www.ncbi.nlm.nih.gov/books/NBK279684/#appendices_Options_for_the_commandline_a
BLAST has a lot of flexibility in how it presents results:
-
Use the
-outfmt
option to specify how the results are presented.- Default value for
-outfmt
is 0 (zero), which produces the standard BLAST report. -outfmt 6
produces a tabular report with a standard set of fields.-outfmt 7
produces a tabular report with comment fields-outfmt 10
produces CSV.
To customize the fields in the tabular/CSV output, see examples in slides 6-8 of https://ftp.ncbi.nlm.nih.gov/pub/education/public_webinars/2018/10Oct03_Using_BLAST/Using_BLAST_Well2.pdf
- Use
-outfmt 11
to save your results as a BLAST archive that you can then reformat with theblast_formatter
application. See slide 9 in https://ftp.ncbi.nlm.nih.gov/pub/education/public_webinars/2018/10Oct03_Using_BLAST/Using_BLAST_Well2.pdf
- Default value for
BLAST Databases.
-
To see BLAST databases on a prepared GCP instance, use the comand
docker run --rm ncbi/blast update_blastdb.pl --showall pretty --source gcp
-
Use
update_blastdb.pl
to download the databases you need. -
Example (note that GCP is specified as source,
BLASTDB_DIR
is defined and points at a directory that exists):docker run --rm -v $BLASTDB_DIR:/blast/blastdb:rw -w /blast/blastdb ncbi/blast update_blastdb.pl --source gcp swissprot_v5
-
Use
blastdbcmd
to interrogate the databases.- Summary of database:
blastdbcmd -db swissprot_v5 -info
full command with docker is
docker run --rm -v $BLASTDB_DIR:/blast/blastdb:ro -w /blast/blastdb ncbi/blast blastdbcmd -db swissprot_v5 -info
- Summary of database:
-
Print accession, scientific name, and title for all entries:
blastdbcmd -db swissprot_v5 -entry all -outfmt "%a %S %t"
-
Print accession and title for all human (taxid 9606) entries:
blastdbcmd -db swissprot_v5 -taxids 9606 -outfmt "%a %t"
-
Print accession, scientific name, and title for
P02185
:blastdbcmd -db swissprot_v5 -entry p02185 -outfmt "%a %S %t"
BLAST programs (this is a brief summary)
-
blastn
: DNA-DNA comparisons. Add-task blastn
to make it more sensitive (and much slower). Default is megablast. -
blastp
: protein-protein comparisons. Add-task blastp-fast
to make it faster (longer words for initial matches) and only marginally less sensitive. -
blastx
: (translated) DNA query-protein comparison. Add-task blastx-fast
to make it faster. -
tblastn
: protein query-(translated) DNA database comparison. Add-task tblastn-fast
to make it faster. -
rpsblast
: protein-PSSM comparison (PSSM is position-specific-scoring matrix). Great for identifying domains in your proteins. -
rpstblastn
: (translated) DNA-PSSM comparison. Great for identifying domains in your translated DNA queries. -
magicblast
: mapper for DNA-DNA comparisons. Can quickly map reads (even long PacBio ones) and identify splice sites.Documentation at https://ncbi.github.io/magicblast/
-
You can extract FASTAs from a BLAST DB:
blastcmd -db <db_name> -entry all -outfmt %f -out <file_name>
-
You can blast against a subset of a db using a:
- gi list:
-gilist <file>
- Negative gi list:
-negative_gilist <file>
- gi list:
Some VMs will have these tools installed:
hisat2 | skesa | guidedassembler_graph | compute-coverage |
---|---|---|---|
python | pip | python3 | pip3 |
C++ | R | Anaconda2 | conda |
bedtools | GATK | picard | BWA |
MiniMap 2 | BowTie 2 | EDirect | HMMer |
samtools | bcftools | HTS JDK | HTS lib |
STAR | abyss | plink-ng | cufflinks |
cytoscape-impl | velvet | tophat | FastQC |
HTSeq | mcl | muscle | MrBayes |
GARLI | Clustal omega | Dedupe | trintyrnaseq |
Based on this cheatsheet.
make sure that
wget
andbzip2
are installed.
- Get the latest version from https://www.anaconda.com/download/#linux (note your version or filename may be different).
$ wget https://repo.continuum.io/archive/Anaconda3-2018.12-Linux-x86_64.sh
- Verify your download
$ sha256sum Anaconda3-5.2.0-Linux-x86_64.sh
- Run the script
$ bash Anaconda3-5.2.0-Linux-x86_64.sh
- Create a jupyter config file
$ jupyter notebook --generate-config
- Create a self-signed SSL certificate
$ mkdir certs``
$ cd certs/$ sudo openssl req -x509 -nodes -days 365 -newkey rsa:1024 -keyout mycert.pem -out mycert.pem`
- Generate a password hash (you will use the same password to access your jupyter notebook remotely)
$ ipython
In [1]: from IPython.lib import passwd
In [2]: passwd()
Enter password:Verify password:
Out[3]: 'sha1:0bebc03bff39:25b6ebdkrisbf0cc3f7e6c8e0f82fcbe9e66801a' Copy thesha
string for later use.
- Edit
.jupyter/jupyter_notebook_config.py
to add the following
Note the path to your mycert.pem file from step 5. Note the
sha
hash from step 6
######################
c.NotebookApp.allow_remote_access = True
# Kernel config
c.IPKernelApp.pylab = 'inline' # if you want plotting support always in your notebook
# Notebook config
c.NotebookApp.certfile = u'/home/username/certs/mycert.pem' #location of your certificate file
c.NotebookApp.ip = '*'
c.NotebookApp.open_browser = False #so that the ipython notebook does not opens up a browser by default
c.NotebookApp.password = u'sha1:ff35ddacee39:e9faaaaa1c6d5008cb50160ad1a00527c9dec09' #edit this with the SHA hash that you generated after typing in Step 9
# This is the port we opened in Step 3.
c.NotebookApp.port = 8080
###############
- Start a screen instance so you can close your terminal without killing jupyter
`$ screen -DR notebook
- Run the notebook as root
$ sudo /home/username/anaconda3/bin/jupyter notebook --config /home/username/.jupyter/jupyter_notebook_config.py --allow-root
-
Press
ctrl+a
thend
to detach from the screen session. -
Browse to https://SERVER:8080/ and enter the password you supplied in step 6, above.