> 데이터 베이스 > MySQL 튜토리얼 > DB 명령어 패키지 초기화 및 mysql 프로토콜 분석

DB 명령어 패키지 초기화 및 mysql 프로토콜 분석

黄舟
풀어 주다: 2017-03-07 13:58:52
원래의
1372명이 탐색했습니다.


git


https://github.com/sea-boat/mysql-protocol

개요

Mysql 연결 연결의 기본 스키마를 변경하려는 경우 클라이언트에서 초기화 DB 명령 패키지를 서버로 보낼 수 있습니다.

mysql 통신 메시지 구조

유형 이름 설명 th >
int 페이로드 길이 는 최하위 바이트부터 3단어로 저장됩니다. 스탠자의 페이로드와 1바이트 시퀀스 번호는 메시지 헤더로 결합됩니다.
int 일련 번호
类型 名字 描述
int<3> payload长度 按照the least significant byte first存储,3个字节的payload和1个字节的序列号组合成报文头
int<1> 序列号
string payload 报文体,长度即为前面指定的payload长度
string payload 메시지 본문, 길이는 이전에 지정된 페이로드 길이입니다. tr>

DB 명령 패키지 초기화

페이로드

1              [02] COM_INIT_DBstring[EOF]    schema name
로그인 후 복사

자세한 내용: http: / /dev.mysql.com/doc/internals/en/com-init-db.html

초기화 명령어 패키지 동작

  1. 초기화 명령어 패키지

/**
 * 
 * @author seaboat
 * @date 2016-09-25
 * @version 1.0
 * <pre class="brush:php;toolbar:false"><b>email: </b>849586227@qq.com
*
<b>blog: </b>//m.sbmmt.com/;/pre>
 * <p>mysql init db packet.</p>
 */public class InitDBPacket extends MySQLPacket {
    public byte[] schema;    public void read(byte[] data) {
        MySQLMessage mm = new MySQLMessage(data);
        packetLength = mm.readUB3();
        packetId = mm.read();
        mm.read(); // skip COM_INIT_DB
        this.schema = mm.readBytes();
    }    public void write(ByteBuffer buffer) {
        BufferUtil.writeUB3(buffer, calcPacketSize());
        buffer.put(packetId);
        buffer.put(COM_INIT_DB);
        buffer.put(schema);
    }    @Override
    public int calcPacketSize() {        int i = 1;
        i += schema.length;        return i;
    }    @Override
    protected String getPacketInfo() {        return "MySQL Init DB Packet";
    }

}
로그인 후 복사

위 내용은 mysql 프로토콜의 초기화 DB 명령어 패키지와 파싱 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(m.sbmmt.com)를 참고해주세요!


원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿