ํฐ์คํ ๋ฆฌ ๋ทฐ
์ต๊ทผ์ DDL์ ์คํ์ํค๋ ๊ณผ์ ์์ ๋ชจ๋ Insert ์ฟผ๋ฆฌ๊ฐ ๋๊ธฐ ์ํ์ ๋น ์ ธ ๋ฐ๋ฆฌ๋ ํ์์ ๋ฐ๊ฒฌํด์ ์ ํํ ์์ธ ๋ถ์์ ์งํํ๊ณ ๊ทธ ๋ด์ฉ์ ๊ธฐ๋กํฉ๋๋ค.
๋ฌธ์ ๊ฐ ๋ฐ์ํ๋ ์ํฉ
1. datagrip์์ ๋ฌด๊ฑฐ์ด select ์ฟผ๋ฆฌ ์คํ
2. datagrip์์ ์๋ก์ด ์ธ์
์ผ๋ก ALTER TABLE ์ฟผ๋ฆฌ๋ฅผ online DDL๋ก ์คํ
3. server application์์ Insert ์ฟผ๋ฆฌ๊ฐ ๋๊ธฐ ์ํ์ ๋น ์ง
์ผ๋ฐ์ ์ผ๋ก ๋ดค์ ๋๋ ์ค์ datagrip ๋ญ๊ฐ ๋ฌธ์ ์ง? ๋ผ๋ ์๊ฐ์ด ๋ค ์ ์๋๋ฐ์. ์์ธํ ๋ด์ฉ์ ์ข ๋ ์๋์์ ํ์ด๋ณด๊ฒ ์ต๋๋ค.
๋ฌธ์ ์์ธ์ ๋ค์๊ณผ ๊ฐ์์ด์
MySQL์์ ALTER TABLE ์ฟผ๋ฆฌ๋ ์คํ์ ์ํด์ table metadata lock(=MDL)์ ํ๋ํด์ผ ํ๊ณ ์ด ๋, Exclusive Lock(๋ฐฐํ์ ๋ฝ)์ ํ์๋ก ํ๋๋ฐ์.
์ ์ํฉ์์ ๋ฌธ์ ๋ ALTER TABLE ์ฟผ๋ฆฌ๊ฐ *์ด๋ค ์ด์ ๋ก ์ธํด์ Exclusive Lock์ ํ๋ํ์ง ๋ชปํด์ ๋๊ธฐํ๋ ์ํฉ์ด์๊ณ
์ดํ์ ๋ค์ด์ค๋ Insert ์ฟผ๋ฆฌ๋ Shared Lock(๊ณต์ ๋ฝ)์ ํ์๋ก ํ๋๋ฐ, Exclusive Lock์ด MySQL์์ ์ฒ๋ฆฌ ์ฐ์ ์์๊ฐ ๋๊ธฐ ๋๋ฌธ์ ๋๊ธฐ ์ํ์ ๋น ์ง๊ฒ ๋์์ต๋๋ค.
์์์ ์ธ๊ธํ *์ด๋ค ์ด์ ์ ์ ์ฒด๋ "datagrip์์ ๋ฌด๊ฑฐ์ด select ์ฟผ๋ฆฌ ์คํ"์ด์๊ณ , ์ด select ์ฟผ๋ฆฌ๊ฐ ์๋์น ์๊ฒ Shared Lock์ ์ก๊ณ ์๋ ์ํฉ์ด์ฌ์ ALTER TABLE ์ฟผ๋ฆฌ๊ฐ Exclusive Lock์ ํ๋ํ ์ ์๋ ์ํฉ์ด๋ผ๋ ๊ฑธ ์์์ต๋๋ค.
์ฌ์ฐํด๋ณด๋ฉด ๋ฐ๋ก ์๋์ ๊ฐ์ ์ํฉ์ธ ๊ฑด๋ฐ์ ๐ค
์ค์ ๋ก metadata lock ํํฉ์ ํ์ธํ ์ ์๋ performance_schema.metadata_locks ํ
์ด๋ธ์
์ดํด๋ณด๋ฉด SHARED_READ LOCK์ด ์กํ์๋ ๊ฑธ ํ์ธํ ์ ์์์ต๋๋ค.
๊ทธ๋์ ์๋์น์๊ฒ ์ค๋ ๋์ํ๊ณ ์๋ select ์ฟผ๋ฆฌ ํ๋ก์ธ์ค๋ฅผ KILL ํ๊ณ ALTER ์ฟผ๋ฆฌ๋ฅผ ์คํํด์ ์ด์๋ฅผ ํด๊ฒฐํ ์ ์์์ต๋๋ค.
๊ทธ๋ฐ๋ฐ ์ฌ์ค SELECT ์ฟผ๋ฆฌ์์ Transaction์ ๋ช ์์ ์ผ๋ก ์คํํ ์ ์ด ์์ต๋๋ค
์ฌ์ค ์ ์์๋ ์ดํด๋ฅผ ๋๊ธฐ ์ํด ์ผ๋ถ๋ฌ ๋ช
์์ ์ผ๋ก Transaction์ ์์ํ์ต๋๋ค.
๊ทธ๋ฆฌ๊ณ ์ค์ ์ํฉ์์ "datagrip์์ ๋ฌด๊ฑฐ์ด select ์ฟผ๋ฆฌ ์คํ"ํ ๋ Transacton์ ์คํํ ์ด์ ๋ ์์๊ณ ๋ช
์์ ์ผ๋ก ์คํํ ์ ์ด ์์์ต๋๋ค.
๊ทธ๋ ๋ค๋ฉด Datagrip์์ ์๋์ผ๋ก Transaction์ ์ก์๋ค๋ ์ด์ผ๊ธฐ๊ฐ ๋๋๋ฐ, ์ ๊ทธ๋ฐ ๊ฑธ๊น์?
Transaction Mode : Auto
Datagrip์๋ Transaction Mode ์ต์
์ด ์กด์ฌํ๋๋ฐ์.
์ฌ๊ธฐ์ Auto ์ต์
์ ์ ํํ๋ฉด (์๋ง ๊ธฐ๋ณธ๊ฐ์ด์๋ ๊ฒ ๊ฐ์ต๋๋ค) Transaction commit์ Datagrip์์ ๊ด๋ฆฌํ๊ฒ ๋ฉ๋๋ค.
๋ณ๋ค๋ฅธ ์ถ๊ฐ ์ค์ ์์ด Datagrip์ ์ฌ์ฉํ์๊ณ ์ฌ๊ธฐ์ Isolation level์ด REPEATABLE READ(์ด๊ฒ๋ ๊ธฐ๋ณธ๊ฐ์ด์๋ ๊ฒ ๊ฐ์ต๋๋ค)๋ก ์กํ์์ด์ SELECT ์ฟผ๋ฆฌ ์คํ ์์ SHARED_READ lock์ด ์กํ๊ฒ ๋ ๊ฒ์ด์์ต๋๋ค.
์ดํ Action Item
์ ์ด์๋ฅผ ๊ฒช์ ์ดํ๋ก ์ฌ๋ฐ ๋ฐฉ์ง๋ ์ค์ํ๊ธฐ ๋๋ฌธ์ SHARED_READ lock์ ์ค๋ ์ก๊ณ ์๋ ์ฟผ๋ฆฌ๋ฅผ ๊ฐ์งํ๋ ์๋ํ๋ ๋ชจ๋ํฐ๋ง์ ์ํ ๊ณํ์ ์ธ์๋์๋๋ฐ์. ์์ธํ ๋ด์ฉ์ ๋ค๋ฅธ ๊ธ์์ ๋ค๋ค๋ณด๊ฒ ์ต๋๋ค. ์ฝ์ด์ฃผ์ ์ ๊ฐ์ฌํฉ๋๋ค :)
'BackEnd' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
Zero Copy๋ฅผ ์์๋์? with kotlin S3 upload (1) | 2024.11.24 |
---|---|
์ฐ๋ฆฌ ์๋ฒ์ OOMKilled ์ฅ์ ๊ฐ ๋ฐ์ํ์ด์ - ํ๊ณ ํธ (0) | 2024.11.10 |
MySQL ์คํ ๊ณํ ํบ์๋ณด๊ธฐ (1) | 2024.04.28 |
ํธ๋์ญ์ ๊ฒฉ๋ฆฌ ์์ค(isolation level)์ด๋? (0) | 2024.03.03 |
AWS Elastic Beanstalk ๋จ์ผ ์ธ์คํด์ค ๋ฌด์ค๋จ ๋ฐฐํฌํ๊ธฐ (0) | 2023.10.08 |
- Total
- Today
- Yesterday
- ์คํ/ํ
- AWS re:Invent 2023
- ํ๋ก๊ทธ๋๋จธ์ค
- Aws Reinvent 2023
- grpc client
- ๊น์ด/๋๋น ์ฐ์ ํ์(DFS/BFS)
- ์ข์ ์์ง๋์ด
- rate limit
- ์ถ์ ์ง๋
- mysql metadata_locks
- 2024ํ๊ณ
- 2023 ๊ฐ๋ฐ์ ํ๊ณ
- Go
- ์ฝ๋ฉํ ์คํธ
- kotlin s3 upload
- ๋ฐฑ์ค
- mysql
- ์๊ณ ๋ฆฌ์ฆ
- ์ฅ์ ํ๊ณ
- HTTP
- 2023 ํ๊ณ
- ์ข์ ๊ฐ๋ฐ์ ๋๊ธฐ
- ์ข์ ์ฝ๋๋ ๋ฌด์์ธ๊ฐ?
- ํด์
- golang oomkilled
- Golang
- mysql ์คํ ๊ณํ
- ์ข์ ๊ฐ๋ฐ์
- ํธ๋์ญ์ ๊ฒฉ๋ฆฌ ์์ค
- ํ(Heap)
์ผ | ์ | ํ | ์ | ๋ชฉ | ๊ธ | ํ |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |