Docker封装生物信息学宏基因组流程

宏基因组学(metagenomics)是一种以环境样品中的微生物群体所有基因组作为研究对象,利用基因组学的研究策略研究环境样品中所包含的全部微生物的遗传组成及其群落功能的新的研究微生物多样性的方法。宏基因组不依赖于微生物的分离培养,克服了传统的纯培养方法的技术限制,为研究和开发利用占微生物种类99%以上的未可培养的微生物提供了一种新的途径和良好的策略; 可以得到环境中丰度较低的,甚至是痕量微生物的信息,为研究低丰度微生物提供了途径;它引入了宏观生态的研究理念,对环境中微生物菌群的多样性、功能活性等宏观特征进行研究,可以更准确地反应出微生物生存的真实状态。

宏基因组的生物信息分析,首先对测序数据进行质控,如果存在宿主基因组在质控过后需要去除宿主基因组。对质控过的数据进行组装,基因预测以及功能注释。通过测序数据与不同物种分类数据库的比对分析,得到样本间的物种分类信息,并找寻出差异丰度物种。此外还可以通过比较样本间差异丰度基因寻找可应用于功能比较的biomarker。宏基因组的生物信息分析流程见下图:

图片.png

1.环境配置

1.启动docker镜像
拉取一个基础镜像,系统为ubuntu 18.04

docker  pull ubuntu
docker run -itd  ubuntu

# 进入容器

docker  exec -it  ae5051a30635 /bin/bash

下载conda---缺少wget命令

apt-get update

apt-get install wget

# 下载conda:
wget [https://repo.anaconda.com/miniconda/Miniconda2-latest-Linux-x86_64.sh](https://repo.anaconda.com/miniconda/Miniconda2-latest-Linux-x86_64.sh)
# mwget软件安装下载   该软件可以加快下载数据速度,多线程下载
wget [http://jaist.dl.sourceforge.net/project/kmphpfm/mwget/0.1/mwget_0.1.0.orig.tar.bz2](http://jaist.dl.sourceforge.net/project/kmphpfm/mwget/0.1/mwget_0.1.0.orig.tar.bz2)
# 关于mwget下载参考有参流程

2.软件安装

3.1 数据评估软件fastqc

    conda install -c bioconda fastqc=0.11.9

3.2 数据评估软件multiqc

conda install -c bioconda multiqc #安装multiqc

3.3 数据预处理软件fastp

conda install -c bioconda fastp=0.20.0

3.4 去duplicates 软件nextclip

git clone [https://github.com/richardmleggett/nextclip.git](https://github.com/richardmleggett/nextclip.git)  #下载nextclip

cd nextclip

make

3.5 比对软件diamond

conda install -c bioconda diamond #安装diamond

3.6 物种及功能注释megan

conda install -c bioconda megan #安装megan

3.7 比对软件blast

conda install -c bioconda blast #安装blast

3.8 k-mer分析软件sourmash

conda install -c bioconda sourmash #安装sourmash

3.9 组装软件spades

conda install -c bioconda spades #安装spades

4.0 基因组注释软件prokka

conda install -c bioconda prokka #安装prokka

4.1 非冗余基因集分析软件cd-hit

conda install –c bioconda cd-hit #安装cd-hit

4.2 sam文件处理工具samtools

conda install –c bioconda samtools #安装samtools

4.3 工具集picard

    conda install -c bioconda picard

软件安装完成,未报错

补充软件:

bowtie2-2.3.5.1

conda install -c bioconda bowtie2

conda install -c bioconda quast

1.1 原始数据质控
1.1.1 数据预处理及质量评估
1.1.2与宿主参考基因组比对(无宿主则省略)----------------bowtie2
1.2拼接组装及注释-------------------------------------------metaSPAdes[1](SPAdes-3.13.1,kmer默认参数 –k 21,33,55)
1.3 基因组装结果的预测--------------------------------------QUAST
1.4 基因预测-------------------------------------------------MetaGeneMark
1.5 噬菌体预测-----------------------------------------------Virsorter (VIRSorter 1.0.5)
1.6 转座元件预测 --------------------------------------------RepeatMasker[4](version 4.0.9)
1.7 非冗余基因集构建----------------------------------------CD-HIT
1.8 基因集注释-----------------------------------------------BLASTP(Version 2.2.31)
1.9 通用数据库注释------------------------------------------BLASTP(Version 2.2.31)
2.0 耐药基因数据库CARD功能注释--------------------------RGI (Resistance Gene Identifier)
2.1 CAZy数据库功能注释------------------------------------dbCAN2[13](http://bcb.unl.edu/dbCAN2/
2.2 基因丰度-------------------------------------------------bowtie2
2.3 物种组成及归属分析-------------------------------------MetaPhlAn2

问题:
噬菌体预测模块相关软件:
Virsorter数据库下载失败
VirFinderR包--微测试

以下流程代码参考 https://github.com/YongxinLiu/Liu2020ProteinCell/blob/master/2Pipeline/metagenome_soft_db.sh

按照流程完成各个模块安装

整理流程-----主要模块脚本:

1.step1.sh--数据质控与宿主去除

js() {
    jq ".$1" $config | sed 's/"//g'
}
config="analysis-profile.json"
samplenames="$(js samplenames)"
fastq_dir="$(js fastq_dir)"


mkdir -p qc1
for sample in $samplenames
do
  kneaddata -i $fastq_dir/${sample}_1_jie.fq.gz -i $fastq_dir/${sample}_2_jie.fq.gz -o qc1 -v -t 3 \
  --remove-intermediate-output \
  --trimmomatic /home/zhangxc/miniconda3/share/trimmomatic-0.39-1/ \
  --trimmomatic-options 'ILLUMINACLIP:/home/zhangxc/miniconda3/share/trimmomatic-0.39-1/adapters/TruSeq3-PE.fa:2:40:15 SLIDINGWINDOW:4:20 MINLEN:50' \
  --bowtie2-options '--very-sensitive --dovetail' -db /data/zhangxc/database/kneaddata/human_genome/Homo_sapiens
done

结果如下:

图片.png

将创建四种类型的输出文件:

  1. 修剪后过滤序列的最终文件
    kneaddata_demo_output/demo_kneaddata.fastq
  2. 来自数据库测试的污染物序列
    kneaddata_demo_output/demo_kneaddata_demo_db_bowtie2_contam.fastq
  3. 来自运行的日志文件
    kneaddata_demo_output/demo_kneaddata.log
  4. 修剪序列的fastq文件
    kneaddata_demo_output/demo_kneaddata.trimmed.fastq


    图片.png

2.step2.sh 序列拼接

增加判断软件参数

js() {
    jq ".$1" $config | sed 's/"//g'
}
config="analysis-profile.json"
samplenames="$(js samplenames)"
fastq_dir="$(js fastq_dir)"
genome_index="$(js genome_bowtie2index)"
trimmomatic="$(js trimmomatic)"
project_dir="$(js project_dir)"
single="$(js single)"
Assembly="$(js Assembly)"
if [[ $Assembly == "spades" ]]; then
      if [ $single == "TRUE" ]; then

      echo "*************使用spades软件进行clean_data序列拼接***************"
      mkdir -p $project_dir/step2_Assembly_spades
      cd $project_dir/step2_Assembly_spades

      metaspades.py -t 9 -m 500 \
            `ls $project_dir/step1_QC/*_kneaddata_paired_1.fastq|sed 's/^/-1 /'| tr '\n' ' '` \
            `ls $project_dir/step1_QC/*_kneaddata_paired_2.fastq|sed 's/^/-2 /'| tr '\n' ' '` \
            -o $project_dir/step2_Assembly_spades
      elif [ $single == "FALSE" ]; then
            for sample in $samplenames
                  do
                        mkdir -p $project_dir/step2_Assembly_spades/$sample
                        cd $project_dir/step2_Assembly_spades/$sample
                        metaspades.py -t 9 -m 500 \
                        `ls $project_dir/step1_QC/${sample}*_kneaddata_paired_1.fastq|sed 's/^/-1 /'| tr '\n' ' '` \
                        `ls $project_dir/step1_QC/${sample}*_kneaddata_paired_2.fastq|sed 's/^/-2 /'| tr '\n' ' '` \
                        -o $project_dir/step2_Assembly_spades/$sample
                  mv $project_dir/step2_Assembly_spades/$sample/contigs.fasta > $project_dir/step2_Assembly_spades/${sample}_contigs.fasta
                  done

      fi
elif [[ $Assembly == "megahit" ]]; then
      echo "*************使用Megahit软件进行clean_data序列拼接**************"
      # mkdir -p $project_dir/step2_Assembly_megahit
      # cd $project_dir/step2_Assembly_megahit
      # 确定没有输出目录,否则报错
      megahit -t 2 \
            -1 `ls $project_dir/step1_QC/*_kneaddata_paired_1.fastq|tr '\n' ','|sed 's/,$//'` \
            -2 `ls $project_dir/step1_QC/*_kneaddata_paired_2.fastq|tr '\n' ','|sed 's/,$//'` \
            -o $project_dir/step2_Assembly_megahit

      echo "**************megahit拼接完成**********************************"
fi

echo "**************使用quast软件进行拼接序列评估***************"
mkdir -p $project_dir/step2_Quast
cd $project_dir/step2_Quast
ln -s $project_dir/step2_Assembly_megahit/final.contigs.fa ./
quast.py $project_dir/step2_Quast/final.contigs.fa -o $project_dir/step2_Quast/quast -t 2
# # metaquast.py result/megahit/final.contigs.fa -o result/megahit/metaquast #(可选,需下载数据库)
# 可选metaquast评估,更全面,但需下载相关数据库,受网速影响可能时间很长

暂时更新到这……

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352