mysql deadlock
# DataBase/Mysql(MariaDB)2021. 12. 23. 13:30mysql deadlock

mysql InnoDB Lock 종류 Shared lock (S) Row-level lock SELECT 위한 read lock shared lock이 걸려있는 동안 다른 트랜잭션이 해당 row에 대해 X lock 획득(exclusive write)은 불가능하지만 S lock 획득(shared read)은 가능 한 row에 대해 여러 트랜잭션이 동시에 S lock을 획득 가능 Exclusive lock (X) Row-level lock UPDATE, DELETE 위한 write lock exclusive lock이 걸려있으면 다른 트랜잭션이 해당 row에 대해 X, S lock을 모두 획득하지 못하고 대기해야 한다. Intention lock Table-level lock 테이블 안의 “row에 대해서 ..

mysql 기간별 select query(현재기준)
# DataBase/Mysql(MariaDB)2021. 9. 9. 17:44mysql 기간별 select query(현재기준)

현재 기준 하루/일주일/한달 select query 하루 SELECT COLUMN1,2.... FROM TABLE WHERE DATE_COLUMN BETWEEN DATE_ADD(NOW(),INTERVAL -1 DAY ) AND NOW(); 일주일 SELECT COLUMN1,2.... FROM TABLE WHERE DATE_COLUMN BETWEEN DATE_ADD(NOW(),INTERVAL -1 WEEK ) AND NOW(); 한달 SELECT COLUMN1,2.... FROM TABLE WHERE DATE_COLUMN BETWEEN DATE_ADD(NOW(),INTERVAL -1 MONTH ) AND NOW();

mysql show processlist 쓰레드 실시간 정보
# DataBase/Mysql(MariaDB)2021. 6. 29. 09:59mysql show processlist 쓰레드 실시간 정보

[darksharavim.tistory.com] mysqladmin -p -i5 -r processlist Enter password: +----+-------------+-----------+----+---------+--------+-----------------------+------------------+----------+ | Id | User | Host | db | Command | Time | State | Info | Progress | +----+-------------+-----------+----+---------+--------+-----------------------+------------------+----------+ | 2 | system user | | | Sleep |..

mariadb galera clustering
# DataBase/Mysql(MariaDB)2021. 6. 24. 15:26mariadb galera clustering

설치환경 centos 7.9 db-node1 - 192.168.132.138 db-node2 - 192.168.132.139 db-node3 - 192.168.132.140 반드시 3개이상으로 구성추천 그렇지 않을 경우 split brain발생위험(서로 마스터 인식하여 오류 발생하는 이슈) 1. Galera Cluster설치 #mariadb repo 다운로드 [root@db01 yum.repos.d] curl -sS https://downloads.mariadb.com/MariaDB/mariadb_repo_setup | bash #모든 repo 캐시빌드 [root@db01 yum.repos.d] yum makecache fast #MariaDB설치 [root@db01 yum.repos.d] yum -y ..

mariadb 로컬 접근 가능 계정 추가
# DataBase/Mysql(MariaDB)2020. 3. 27. 13:31mariadb 로컬 접근 가능 계정 추가

1. 로컬에서만 접속가능 계정 추가 create user '사용자'@'localhost' identified by '비밀번호'; 2. 권한 부여 2-1. 모든DB일 경우 grant all privileges on *.* to '사용자'@'localhost'; 2-2. 특정DB일 경우 grant all privileges on DB이름.* to '사용자'@'localhost'; 3. 적용 flush privileges; 4. 권한부여 확인 # userid 와 host명까지 붙여서 검색해야 함 SHOW GRANTS FOR test@localhost; SHOW GRANTS FOR test@'%'; SHOW GRANTS FOR test@'192.168.0.10'; 5. 권한 제거 # 모든 권한을 삭제 # rev..

image