ubuntu(18.04) 安装 blast 并在php中调用

1、下载

https://ftp.ncbi.nlm.nih.gov/blast/executables/blast+/LATEST/

2、解压,配置环境变量

tar zvxf ncbi-blast-2.14.1+-x64-linux.tar.gz

解压后改名为 blast

配置环境变量,可以不配置 使用的时候直接绝对路径使用(本次使用绝对路径)

vim ~/.bashrc  

将下面添加道最后, dir 是解压文件所在的绝对路径,

export BLAST_HOME=/dir/blast
export PATH=$PATH:/dir/blast/bin

使配置生效

source ~/.bashrc

测试安装结果

blastn -version 

如果显示版本信息则说明可正常使用

3、创建数据库

在/dir/blast 下创建文件夹 db/mydb 用来存放不同的数据库

构建数据库:initdb.fasta 是用来构建数据库的源文件

#绝对路径调用,直接使用makeblastdb命令调用可能出现找不到命令的问题,可能是环境变量没有配置好

/dir/blast/bin/makeblastdb -in /dir/blast/db/mydb/initdb.fasta -dbtype prot

结果:

4、测试搜索 test.fasta 是测试序列文件

#采用绝对路径调用

#结果输出到终端

/dir/blast/bin/blastp -query /dir/blast/output/test.fasta -db /dir/blast/db/mydb/initdb.fasta -outfmt 6

#结果输出到文件

/dir/blast/bin/blastp -query /dir/blast/output/test.fasta -db /dir/blast/db/mydb/initdb.fasta -outfmt 6 -out /dir/blast/output/test

结果:

5.在php中调用

//通过blast获取targetID,然后通过targetID获取详细信息
$input_sequence = $data_json['sequence'];  // 从用户前端输入的序列
$file_name = uniqid() . ".fasta";
// 创建临时文件
$tempFile = tempnam("/tmp", $file_name);
//将用户输入的文件写入到临时文件,blast的输入条件只找到了文件输入,不知道可不可以其他形式输入
file_put_contents($tempFile, $input_sequence);
// 执行 BLAST 查询
$output = shell_exec("/dir/blast/bin/blastp -query " . $tempFile . " -db /dir/blast/db/mydb/initdb.fasta -outfmt 6");

echo $output;
相关推荐
萌小丹Fighting10 分钟前
【Postgres_Python】使用python脚本批量创建和导入多个PG数据库
数据库
青灯文案115 分钟前
Oracle 数据库常见字段类型大全及详细解析
数据库·oracle
代码讲故事37 分钟前
从Windows通过XRDP远程访问和控制银河麒麟ukey v10服务器,以及多次连接后黑屏的问题
linux·运维·服务器·windows·远程连接·远程桌面·xrdp
羊小猪~~39 分钟前
MYSQL学习笔记(四):多表关系、多表查询(交叉连接、内连接、外连接、自连接)、七种JSONS、集合
数据库·笔记·后端·sql·学习·mysql·考研
qq_243050793 小时前
irpas:互联网路由协议攻击套件!全参数详细教程!Kali Linux入门教程!黑客渗透测试!
linux·网络·web安全·网络安全·黑客·渗透测试·系统安全
村口蹲点的阿三3 小时前
Spark SQL 中对 Map 类型的操作函数
javascript·数据库·hive·sql·spark
IT北辰3 小时前
Linux下 date时间应该与系统的 RTC(硬件时钟)同步
linux·运维·实时音视频
Jason Yan4 小时前
【经验分享】ARM Linux-RT内核实时系统性能评估工具
linux·arm开发·经验分享
步、步、为营4 小时前
.net无运行时发布原理
linux·服务器·.net
暮湫4 小时前
MySQL(1)概述
数据库·mysql