转码云平台
+ 上传文件即可转码
+ 默认MP4可以设置转码分辨率水印视频清晰度
+ 可以直接编辑ffmpeg命令生成自己想要的格式
+ 日志查看功能
python日志分析脚本
一个简单的python分析nginx日志的脚本,版本为python3。
脚本log.py
import os,re,sys
if len(sys.argv)<3:
print("you must input your log file and anystr")
else:
if os.path.isfile(sys.argv[1]):
logfile=open(sys.argv[1],'r')
alog=None
if len(sys.argv)==4:
alog=open(sys.argv[3],'w')
for line in logfile:
if re.findall(r''+sys.argv[2]+'',line):
print(line)
if alog:
alog.write(line)
if alog:
alog.close()
logfile.close()
else:
print("no log file")
python3 log.py www.abc.com.log '\?s=' ax.log
www.abc.com.log 你的网站日志
‘?s=’正则匹配
ax.log匹配后的文件保持位置(非必需)
详情点击此处 maysrp/pylog
使用rsync备份数据
服务端安装
首先需要安装rsync,Ubuntu下安装apt-get install rsync安装完成后开始配置文件。
配置文件
vim /etc/rsyncd.conf
uid = root
gid = root
use chroot = no
read only = yes
max connections = 10
port = 873
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsync.log
log format = %t %a %m %f %b
syslog facility = local3
timeout = 300
[www]
path = /home/wwwroot/
comment = el.psy.congroo
ignore errors
read only = yes
list = no
auth users = els
secrets file = /etc/rsync.pwd
# exclude = book
# exclude from = /etc/exclude_rsync.info
hosts allow = 备份服务器IP
hosts deny = *
- [www]:需要在客户端中相互对应
- path:需要备份的目录
- comment:设置名称[无关紧要]
- secrets file:密码文件[格式 用户吗:密码]
- auth users:用户名
- exclude:排除目录[相对目录][可以注释掉]
- exclude from:排除目录 文件导入[可以注释掉]
- hosts allow:备份服务器IP,需要填写
- log file:rsync日志查看
密码文件
echo '用户名:密码'> /etc/rsync.pwd
用户名就是前面配置文件的用户名,密码随意设置。
chmod 600 /etc/rsync.pwd
密码文件必需600的权限才能使用
启动rsync
rsync --daemon
该命令将自动读取/etc/rsyncd.conf下的配置来启动rsync。
客户端
安装
安装apt-get install rsync
密码文件设置echo '密码'> /etc/rsync.pwd 此处只需要密码即可。
echo "rsync -avzP --delete --password-file=/etc/rsync.pwd 用户名@服务端ip::www /back/www">/root/back.sh
- –password-file=:密码文件地址
- 用户名@需要备份服务器的ip
- www为服务端中[www]的配置
- /back/www:备份到客户端的地址,必需已经存在不存在请先
mkdir -p /back/www创建。
执行sh /root/back.sh即可运行备份。
crontab -e中添加一个定时任务:
* * */1 * * sh /root/back.sh每日执行一次备份
在命令中添加–bwlimit=1000 限制速度为1000kbps,100M需要–bwlimit=100000
YunBT:人人都可当百度云
YunBT
基于ThinkCMS的YunBT的多用户下载程序,支持Magnet和HTTP下载。每个单独用户支持10个任务,默认下载文件最大为10GB,可以在后台修改。下载完成后用户可以直接查看下载的文件,系统将使用ffmpeg将视频转码为720P的mp4格式的视频,用户可以分享下载完的任务。管理员可以添加用户的下载量及查看管理下载任务。
测试站点:www.yunbt.net
测试站点默认下载限制单个下载小于1GB
截图
分享密码

分享

视频文件

下载列表

后台转码页面

水印及切片设置

Dplayer播放器

安装
服务器环境
Linux Nginx Mysql Php Python
LNMP安装
lnmp 一键安装环境
wget http://soft.vpser.net/lnmp/lnmp1.5.tar.gz -cO lnmp1.5.tar.gz && tar zxf lnmp1.5.tar.gz && cd lnmp1.5 && ./install.sh lnmp
详尽步骤
Redis
lnmp安装redis
./addons.sh install redis
详尽步骤
Aria2
安装Aria2
apt-get update && apt-get install -y aria2
cd /root
mkdir .aria2 && cd .aria2
wget http://webdir.cc/aria2.conf
wget http://webdir.cc/dht.dat
echo '' > /root/aria2.session
screen -dmS aria2 aria2c --enable-rpc --rpc-listen-all=true --rpc-allow-origin-all -c
ffmpeg
apt-get install ffmpeg
PHP
php>7
lnmp下php安装fileinfo插件
lnmp1.4 安装php fileinfo扩展 方法
– 第一步:在lnmp1.4找到php安装的版本
使用命令 tar -jxvf php-7.1.7.tar.bz2 解压
– 第二步: 在解压的php-7.1.7文件夹里找到fileinfo文件夹,然后使用命令 cd /home/xxx/lnmp1.4/src/php-7.1.7/ext/fileinfo进入到fileinfo文件夹
– 第三步:输入/usr/local/php/bin/phpize 得到数据
– 第四步: 使用如下命令编译安装
./configure -with-php-config=/usr/local/php/bin/php-config
make && make install
- 第五步:再修改/usr/local/php/etc/php.ini 查找:extension = 再最后一个extension= 后面添加上extension = “fileinfo.so” 保存,执行
/etc/init.d/php-fpm restart重启。
Nginx
nginx修改fastcgi.conf配置
lnmp下该文件在
/usr/local/nginx/conf/fastcgi.conf
把其中的
#fastcgi_param PHP_ADMIN_VALUE "open_basedir=$document_root/:/tmp/:/proc/";
fastcgi_param PHP_ADMIN_VALUE "open_basedir=$document_root/../:/tmp/:/proc/";
Nginx 配置
下文件为lnmp下的配置
server
{
listen 80;
#listen [::]:80;
server_name www.yunbt.net yunbt.net;
index index.html index.htm index.php default.html default.htm default.php;
root /home/wwwroot/www.yunbt.net/public;
location / {
rewrite ^/file/(.*) /file.php?file=$1 last;
if (!-e $request_filename) {
rewrite ^(.*)$ /index.php?s=/$1 last;
}
}
location /afile{
internal;
alias /home/wwwroot/www.yunbt.net/public/file;
}
#error_page 404 /404.html;
# Deny access to PHP files in specific directory
#location ~ /(wp-content|uploads|wp-includes|images)/.*\.php$ { deny all; }
location ~* ^/(file|upload)/.*\.(php|php5)$ {
deny all;
}
include enable-php.conf;
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
}
location ~ .*\.(js|css)?$
{
expires 12h;
}
location ~ /.well-known {
allow all;
}
location ~ /\.
{
deny all;
}
access_log /home/wwwlogs/www.yunbt.net.log;
}
Mysql
创建数据库名yunbt
用户名yunbt
密码a123456
数据库导入yunbt.sql
数据库配置 data/conf/database.php
python
python3
pymysql
pip3 install pymysql
cron_ffmpeg.py
+ 44行:数据库配置
+ 50行:设置你的web路径
cron_move.py
+ 14行:设置你的web路径
+ 15行:视频文件[无须修改]
+ 74行:数据库配置
cron_download.py
+ 3行:限制下载最大值[单位GB]默认10GB
cron_m3u8.py
+ 10行:数据库配置
+ 17行:设置你的web路径[/public]
权限修改
修改data文件夹下的权限
chmod -R 777 data/
chmod -R 777 public/
cron
添加定时任务
crontab -e
*/1 * * * * curl http://www.yunbt.net/portal/cron/download
*/3 * * * * python3 /home/wwwroot/www.yunbt.net/python/cron_move.py
*/1 * * * * python3 /home/wwwroot/www.yunbt.net/python/cron_ffmpeg.py
*/1 * * * * python3 /home/wwwroot/www.yunbt.net/python/cron_m3u8.py
*/30 * * * * python3 /home/wwwroot/www.yunbt.net/python/cron_download.py
请替换其中www.yunbt.net 为你自己的域名
管理
管理后台 your_domain.com/admin
用户名 admin
密码 a123456
未来计划
目前功能:
– 添加用户下载量
– 下载管理
– 修改当前最大下载文件量[默认10GB]
– 分享功能
– 视频转码
– 工具下载
– 后台转码控制
– Dplayer播放器
– 水印添加
– 视频切片
未来计划:
1. 分享功能
2. 用户转码功能
3. 积分功能
4. 邀请功能
5. 工具下载
6. 水印添加
7. M3U8添加
8. 自动播放转码
bootstrap3笔记
<h1><h2>……<p> <xx class=’row’> 等都为行标签!
.col- 必须要在 .row 下
<ol class="breadcrumb">
<li><a href="#">Home</a></li>
<li><a href="#">Library</a></li>
<li class="active">Data</li>
</ol>
“Home/Library/Data”
路径栏
使用:<ol> <li>以及 .breadcrumb 醒目显示.active
导航条 :
<nav class=’navbar navbar-default navbar-static-top’>
.navbar 导航
.navbar-default 颜色默认 .navbar-inverse [黑色]
.navbar-static-top 禁止在顶部 随着滚动消失
navbar-fixed-bottom 固定在底部
<div class=’container’>
#内部容器大小和之前一样大
<div class=’navbar-header’>
顶部的内容
<a class=’navbar-brand’>
文字或者<img>
</a>
</div>
<div class=’collaspse navbar-collapse’>
必须包含在collaspse navbar-collapse之中
<div class=’navbar-text’>
内容
navbar-link 链接
navbar-text 文字 <a>
navbar-form 表单 <form>
navbar-nav 列表 横向<ul class=’nav navbar-nav’>
</div>
</div>
</div>
</nav>