linux下流量监控命令nload
使用docker-compose 快速搭建Laravel,Nginx,Mysql开发环境
准备工作
- 已经安装了docker
- 已经安装了docker-compose
第一步,下载Laravel,安装依赖
$ cd ~
$ git clone https://github.com/laravel/laravel.git laravel-app
使用php composer 安装Laravle依赖,这里使用的是composer容器,
$ cd ~/laravel-app
先配置下镜像加速
$ docker run --rm -v $(pwd):/app composer config repo.packagist composer https://mirrors.aliyun.com/composer/
安装依赖
$ docker run --rm -v $(pwd):/app composer install -vvv
设置文件权限
sudo chown -R $USER:$USER ~/laravel-app
第二步,创建docer-compose配置文件docker-compose.yml
$ vim docker-compose.yml
内容:
version: '3'
services:
#PHP Service
app:
build:
context: .
dockerfile: Dockerfile
image: digitalocean.com/php
container_name: app
restart: unless-stopped
tty: true
environment:
SERVICE_NAME: app
SERVICE_TAGS: dev
working_dir: /var/www
volumes:
- ./:/var/www
- ./php/local.ini:/usr/local/etc/php/conf.d/local.ini
networks:
- app-network
#Nginx Service
webserver:
image: nginx:alpine
container_name: webserver
restart: unless-stopped
tty: true
ports:
- "80:80"
- "443:443"
volumes:
- ./:/var/www
- ./nginx/conf.d/:/etc/nginx/conf.d/
networks:
- app-network
#MySQL Service
db:
image: mysql:5.7.22
container_name: db
restart: unless-stopped
tty: true
ports:
- "3306:3306"
environment:
MYSQL_DATABASE: laravel
MYSQL_ROOT_PASSWORD: your_mysql_root_password
SERVICE_TAGS: dev
SERVICE_NAME: mysql
volumes:
- dbdata:/var/lib/mysql/
- ./mysql/my.cnf:/etc/mysql/my.cnf
networks:
- app-network
#Docker Networks
networks:
app-network:
driver: bridge
#Volumes
volumes:
dbdata:
driver: local
第三步,数据持久化
创建Dockerfile
$ vim ~/laravel-app/Dockerfile
内容
FROM php:7.2-fpm
# Copy composer.lock and composer.json
COPY composer.lock composer.json /var/www/
# Set working directory
WORKDIR /var/www
# Install dependencies
RUN apt-get update && apt-get install -y \
build-essential \
libpng-dev \
libjpeg62-turbo-dev \
libfreetype6-dev \
locales \
zip \
jpegoptim optipng pngquant gifsicle \
vim \
unzip \
git \
curl
# Clear cache
RUN apt-get clean && rm -rf /var/lib/apt/lists/*
# Install extensions
RUN docker-php-ext-install pdo_mysql mbstring zip exif pcntl
RUN docker-php-ext-configure gd --with-gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/
RUN docker-php-ext-install gd
# Install composer
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer
# Add user for laravel application
RUN groupadd -g 1000 www
RUN useradd -u 1000 -ms /bin/bash -g www www
# Copy existing application directory contents
COPY . /var/www
# Copy existing application directory permissions
COPY --chown=www:www . /var/www
# Change current user to www
USER www
# Expose port 9000 and start php-fpm server
EXPOSE 9000
CMD ["php-fpm"]
配置php
$ mkdir ~/laravel-app/php
$ ~/laravel-app/php/local.ini
内容
upload_max_filesize=40M
post_max_size=40M
配置nginx
$ mkdir -p ~/laravel-app/nginx/conf.d
$ vim ~/laravel-app/nginx/conf.d/app.conf
内容
server {
listen 80;
index index.php index.html;
error_log /var/log/nginx/error.log;
access_log /var/log/nginx/access.log;
root /var/www/public;
location ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_pass app:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
}
location / {
try_files $uri $uri/ /index.php?$query_string;
gzip_static on;
}
}
配置mysql
$ mkdir ~/laravel-app/mysql
$ ~/laravel-app/mysql/my.cnf
内容
[mysqld]
general_log = 1
general_log_file = /var/lib/mysql/general.log
修改环境变量,运行容器
$ cp .env.example .env
.env内容
DB_CONNECTION=mysql
DB_HOST=db
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=laraveluser
DB_PASSWORD=your_laravel_db_password
运行
docker-compose up -d
访问 http://your_server_ip
linux systemd
linux使用systemd启动服务。
vi /etc/systemd/system/frps.service
[Unit]
Description=Frp Server Service
After=network.target
[Service]
Type=simple
User=root
Restart=on-failure
RestartSec=5s
ExecStart=/usr/bin/frps -c /etc/frp/frps.ini
[Install]
WantedBy=multi-user.target
sudo systemctl restart frps
ubuntu下命令行代理
安装proxychains
- proxychains安装
git clone https://github.com/rofl0r/proxychains-ng.git
cd proxychains-ng
./configure
make && sudo make install
sudo cp ./src/proxychains.conf /etc/proxychians.conf
cd .. && rm -rf proxychains-ng
- 编辑proxychains配置
vim /etc/proxychains.conf
socks5 127.0.0.1 1080 //1080改为你自己的端口
- 使用方法
proxychains4 wget http://xxx.com/xxx.zip
ubuntu安装shadowsocks
用PIP安装很简单
sudo apt-get install python-pip
接着安装shadowsocks
sudo pip install shadowsocks
通过以上命令安装shadowsocks,为了避免权限不够,在命令行前加上sudo
安装shadowsocks
https://my.oschina.net/u/1432769/blog/619651
nginx 调试
返回http状态码
<pre><code> location = /test {
return 403 ;
}
</code></pre>
<pre><code><br />### 返回状态码和 body
</code></pre>
<pre><code> location = /test {
default_type text/html ;
return 200 'test test test ';
</code></pre>
}
<pre><code><br />### 返回json格式
</code></pre>
<pre><code>location ^~ /json {
default_type application/json ;
return 200 '{"name":"nanjing_wuxu","result":"success"}';
}
</code></pre>
<pre><code><br />### 返回uri
</code></pre>
location ^~ /json {
default_type text/html ;
return 200 $uri;
}
mysql 任意ip访问
参考:https://easyengine.io/tutorials/mysql/remote-access
修改配置文件
vim /etc/mysql/my.cnf
或者 vim /etc/mysql/mysql.conf.d/mysqld.cnf
#bind-address = 127.0.0.1
#skip-networking
mysql> GRANT ALL PRIVILEGES ON *.* TO 'USERNAME'@'%' IDENTIFIED BY 'PASSWORD' WITH GRANT OPTION;
检查权限
SELECT * from information_schema.user_privileges where grantee like "'root'%";
mysql> FLUSH PRIVILEGES;
golang log
golang 自带了log包,使用起来也非常方便,使用方法
package main
import (
"log"
"os"
)
func main() {
log.Println("111111")
//设置显示文件全名和行号
log.SetFlags(log.Llongfile)
log.Println("111111")
//设置显示短文件名和行号
log.SetFlags(log.Lshortfile)
log.Println("111111")
file, _ := os.Create("test.log")
log.SetOutput(file)
log.Println("write to file")
}
php-7.0.2 session_regenerate_id 报错
本来打算升级生产服务器的php版本到7.0.2,结果测试发现在使用memcached
存储session
的时候session_regenerate_id
报错。
session_start();
session_regenerate_id(false);
报错信息
Catchable fatal error: session_regenerate_id(): Failed to create(read) session ID: memcached (path: 4f522740705c11e4.m.cnhzaliqshpub001.ocs.aliyuncs.com:11211) in
由于我们的开发框架是yii2
,yii2
中是这样调用的
public function regenerateID($deleteOldSession = false)
{
@session_regenerate_id($deleteOldSession);
}
对,yii2
使用了@
符号抑制了错误信息,导致我在查找问题的时候花了3个小时逐行调试,因为没报500错误,但是没有什么错误信息,坑啊!
vagrant LNMP环境
准备工作
安装好vagrant和virtualbox
下载intvdev1.0.box和Vagrantfile,
vagrant box
$ vagrant box list #查看本地已有的box
$ vagrant box add intvdev1.0 /yourdownloadpath/intvdev1.0.box #添加到本地的box列表中
$ vagrant box list #确认已经添加成功
新建工作目录
$ mkdir ~/vagrant_dev
$ cd vagrant_dev
$ cp /yourdownloadpath/Vagrantfile ./ #把之前下载的Vagrantfile拷贝到当前目录
$ vagrant up #启动虚拟机
$ mkdir www #创建web根目录
在www目录下新建一个index.php文件
用浏览器访问http://localhost:8081/index.php
来测试
高迸发下性能优化
hello world
http://rango.swoole.com/archives/508
php性能优化
- 运行环境
- php7,比php5快两倍以上
- opcache
- php-fpm进程数,根据系统总内存数/单个进程占用的内存数据,单个进程的内存数比较难估
- io操作优化
- 使用cache,nosql > db
- 减少io操作(包括cache),合并多个操作,mget()
- 外部接口调用需要谨慎,对其性能要评估
- 异步处理某些操作,比如发短信,发红包等业务。会使用到队里服务,最简单的redis队列或者db模拟队列
- php不存在代码级别的锁,但要防止io锁操作,比如DB锁(update 同一行)
- 减少memcache的热点数据,热点数据会导致只使用mc集群中的单台机器,解决方法应该是设置多级缓存,这会带来逻辑上的增长和运维成本的增加
性能测试工具
- 先单个请求的时间消耗,比如之前100ms,优化后50ms
- 使用apache ab做并发测试
ab -c10 -100 http://abc.com/index.php