목차

1. 사용중인 Oracle DB 버전 & JDK의 버전에 맞는 ojdbc jar파일을 받기

2-1. 단일 Oracle DB와 연동시 설정 방법

2-2. 1개 이상의 Oracle DB와 연동시 설정 방법(ex. oracle rac 구성 등)

3. Tomcat 로그파일(=catalina.out)에서 에러 발생여부 확인

 


※ 참고내용(DB의 SID, ServiceName)
1) SID : DB 하나의 인스턴스(SID가 1개)

SELECT instance_name FROM v$instance;



2) Service Name : 1개 이상의 DB인스턴스를 모여진 시스템(SID가 여러개)

SELECT name FROM v$services;

 

※ SID, ServiceName 관련 참고 URL

https://corona-world.tistory.com/87

https://change-words.tistory.com/entry/Oracle-SID-ServiceName


1. 사용중인 Oracle DB 버전 & JDK의 버전에 맞는 ojdbc jar파일을 받기

- Oracle DB버전과 사용중인 JDK 버전에 따른 ojdbc 버전은 아래 URL의 내용 참고

https://oingdaddy.tistory.com/372
https://jsp-making.tistory.com/489

 

maxTotal
(=maxActive)
커넥션 풀에서 최대 DB커넥션 값. 동시 접속 가능한 커넥션 수. 
설정값을 -1로 설정시, 무제한으로 적용 됨.
maxIdle 커넥션 풀에서 유지하는 유휴 커넥션의 수.
설정값을  -1로 설정시 무제한으로 적용 됨.
maxWaitMillis
(=maxWait)
풀에서 사용 가능한 커넥션이 없을 경우, 커넥션이 생길때까지 대기하는 시간을 설정(msec 단위). 
설정값을  -1로 할 경우 무제한으로 대기한다.

2-1. 단일 Oracle DB와 연동시 설정 방법

- tomcat설치경로/conf/context.xml에 아래 내용을 입력한다.

vi context.xml

<Context>
(중략)

<Resource 
		name="jdbc/(dbname입력)" 
		auth="Container"             
		type="javax.sql.DataSource" 
		driverClassName="oracle.jdbc.OracleDriver"
		url="jdbc:oracle:thin:@(DB서버의IP):1521:(DB_SID)"
		username="(username입력)" 
		password="(password입력)"
		validationInterval="30000" // 이 시간 안에는 validationquery를 하지 않는다. default 값은 30000
		validationQuery="SELECT 1 FROM DUAL" // connection 유효성 체크 query이다. oracle에는 "SELECT 1 FROM DUAL"을 넣는다.
		maxTotal="20" 
		maxIdle="10"
		maxWaitMillis="-1"   />

</Context>

 

- Tomcat설치경로/conf/web.xml에 아래 내용을 입력한다.

vi web.xml

(중략)

	<resource-ref>
		 <description>Oracle Datasource example</description>
		 <res-ref-name>jdbc/(dbname입력)</res-ref-name>
		 <res-type>javax.sql.DataSource</res-type>
		 <res-auth>Container</res-auth>
	</resource-ref>

</web-app>

 

※ 참고 URL

https://velog.io/@jwa/Tomcat-JDBC-%EC%84%A4%EC%A0%95
https://sarc.io/index.php/tomcat/21-tomcat-datasource


2-2. 여러개의 Oracle DB와 연동시 설정 방법(ex. oracle rac 구성 등)

- tomcat설치경로/conf/context.xml에 아래 내용을 입력한다.(단일구성과 다름)

vi context.xml

(중략)

	<Resource
		name="jdbc/(dbname입력)"
		auth="Container"
		type="javax.sql.DataSource"
		validationQuery="SELECT 1 FROM DUAL"
		validationInterval="30000"
		driverClassName = "oracle.jdbc.driver.OracleDriver"
		description="Oracle Datasource"
		url="jdbc:oracle:thin:@(DESCRIPTION=(FAILOVER=ON)(LOAD_BALANCE=ON)(ADDRESS=(PROTOCOL=TCP)(HOST=db서버1_IP입력)(PORT=1521))(ADDRESS=(PROTOCOL=TCP)(HOST=db서버2_IP입력)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=DB_ServiceName입력)))"
		username="(username입력)"
		password="(password입력)"
		maxTotal="100"
		maxIdle= "30"
		maxWaitMillis= "10000"           />


</Context>

 

 

- Tomcat설치경로/conf/web.xml에 아래 내용을 입력한다.

vi web.xml

(중략)

	<resource-ref>
		 <description>Oracle Datasource example</description>
		 <res-ref-name>jdbc/(dbname입력)</res-ref-name>
		 <res-type>javax.sql.DataSource</res-type>
		 <res-auth>Container</res-auth>
	</resource-ref>

</web-app>

 

※ 참고 URL

https://mcpaint.tistory.com/199


 

https://change-words.tistory.com/entry/Oracle-SID-ServiceName
https://oingdaddy.tistory.com/372
https://jsp-making.tistory.com/489
https://corona-world.tistory.com/87

 

 

 

'Infra > DB' 카테고리의 다른 글

DB Log(제너럴로그, 슬로우쿼리로그)  (0) 2024.01.15
HA, RAC 구성에 대해(Oracle)  (0) 2024.01.15
Tomcat 10.1 & MariaDB 10.6.15 연동, DBCP 적용  (0) 2023.10.26
Mariadb 설치(RHEL8)  (0) 2023.10.25

1. 제너럴 로그(general_log)
- Mysql, MariaDB에서 실행되는 모든 쿼리에 대한 내용 기록
- 쿼리 실행간 발생한 에러, 쿼리의 내용 등 기록된다.

[general_log 설정 확인]
show variables like '%general%';

[general_log 활성화/비활성화]
set global general_log = ON;
set global general_log = OFF;


2. 슬로우쿼리로그
- 클라이언트가 실행한 쿼리가 일정 시간 이상 지나도록 완료되지 못한 슬로우쿼리에 대한 로그
- 슬로우쿼리가 많으면 DB성능에 좋지 않다.
- 실행중에 에러가 발생한 슬로우쿼리는 슬로우쿼리로그에 기록하지 않는다.


참고URL
https://dotherealthing.tistory.com/16

Oracle HA 구성(=Oracle High Availavility)
- 서버 2대를 이용하여 Active-Standby 구성
- 모든 커넥션은 Active 서버로 맺으며, Standby에는 커넥션을 맺지 않는다.
- Active서버에 장애가 발생하면, Standby 서버가 Active로 승격하여 작동한다.
- Standby서버가 Active로 승격되는 동안의 커넥션은 유실된다.(치명적)
- 각 서버의 스토리지에 데이터를 저장하며, 수시로 DB 데이터에 대한 동기화가 필요하다.
- RAC 구성보다는 비용적으로 아낄 수 있다.

Oracle RAC 구성(Real Application Cluster)
- 2개 이상의 노드가 하나의 스토리지를 바라보고 있는 구성, 안정성이 좋다.
- 모든 노드가 Active이며, 하나의 스토리지를 바라보고 있어서 성능저하가 되지 않는다.
- HA구성보다 복잡한 구조를 갖고 있으며, 비싸다.

참고URL
https://greatepig.tistory.com/14

<DBCP란?>

- 어플리케이션이 DB와 연결을 하기위한 Connection을 미리 만들어 둔 Pool을 의미한다.

- DB와 연결이 필요할 경우, Pool에 있는 Connection을 사용하고 종료 후 Pool에 반환한다.

- DBCP를 사용하는 이유 : DB와 커넥션을 맺고 끊는 작업은 리소스 소모가 크기에 보완하기 위함.

 

※ DBCP 참고URL

https://zzang9ha.tistory.com/376

https://choitaetae.tistory.com/99


[목차]

1. 테스트 DB 생성 + 테스트 Table 생성하기

2. Tomcat과 MariaDB 연동작업

3. DB연동 확인

 

※ 사전 준비사항

1) 아파치 + 톰캣 연동 완료 된 환경

2) MariaDB 설치 완료 된 환경


1. 테스트 DB 생성 + 테스트 Table 생성하기

# Test용 DB를 생성한다.
mysql -u root -p
Enter password: (암호 입력)

# DB 생성하기
MariaDB [(none)]> use mysql ;
MariaDB [mysql]> create database test1;

# 생성한 DB에 대한 권한 설정하기
MariaDB [mysql]> grant all privileges on *.* to 'root'@'%' identified by 'P@ssw0rd(=root의 패스워드)';
Query OK, 0 rows affected (0.001 sec)

MariaDB [mysql]> flush privileges;
Query OK, 0 rows affected (0.000 sec)

# 생성한 DB로 이동
MariaDB [mysql]> use test1;
Database changed

# Table 생성하기
MariaDB [test1]> create table table1 (id varchar(20) primary key, pw varchar(20));
Query OK, 0 rows affected (0.031 sec)

# Table에 data 입력
MariaDB [test1]> INSERT INTO table1 (id, pw) VALUES ('admin', 'admin123');
Query OK, 1 row affected (0.001 sec)

# Table 내용 조회
MariaDB [test1]> SELECT * FROM table1;
+-------+----------+
| id    | pw       |
+-------+----------+
| admin | admin123 |
+-------+----------+

 

2. Tomcat과 MariaDB 연동작업

- MariaDB Connector를 Tomcat의 lib 디렉토리 안에 넣어주면 된다.

1) 아래 홈페이지 접속

https://mariadb.com/downloads/connectors/connectors-data-access/java8-connector

 

2) wget으로 MariaDB Connector 파일(jar)을 서버로 다운로드 한다.

# jar 파일 다운로드
wget https://dlm.mariadb.com/3418057/Connectors/java/connector-java-2.7.10/mariadb-java-client-2.7.10.jar

# jar 파일 복사
cp -arp mariadb-java-client-2.7.10.jar  /home/tomcat1/lib
cp -arp mariadb-java-client-2.7.10.jar  /home/tomcat2/lib

 

3. DB연동 확인

1) Tomcat 설치 경로 내 webapps/ROOT/index.jsp 파일 내용을 아래와 같이 수정한다.

<%-- index.jsp 내용 --%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.Connection"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF8"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Test</title>
</head>
<body>
 
<%
Connection conn = null;
String url = "jdbc:mariadb://localhost:3306/(생성한 DB명을 여기 입력)";
String id = "root";							// 접속을 위한 계정의 ID
String pw = "(root 패스워드 여기 입력)";	// 접속을 위한 계정의 암호
Class.forName("org.mariadb.jdbc.Driver");
conn = DriverManager.getConnection(url, id, pw);
out.println("<h1>MariaDB DB 연결 성공</h1>");
%>
 
</body>
 
</html>

 

2) 브라우저에서 확인

- 아래와 같은 화면이 나오면 정상적으로 완료

 

 

※ 참고 URL

https://passing-story.tistory.com/entry/Linux-%EC%9A%B0%EB%B6%84%ED%88%AC-Tomcat9-MariaDB-%EC%97%B0%EB%8F%99-Ubuntu-Tomcat9-MariaDB-%EC%97%B0%EB%8F%99

[목차]

1. MariaDB 설치 진행

2. MariaDB 기본 설정(DB 기동 중 진행해야 함. mariadb-secure-installation)


1. MariaDB 설치 진행

1) mariadb 홈페이지에서 다운받을 버전을 선택한다.

- 해당 포스팅에서는 10.6.15 버전을 다운로드 함

- https://mariadb.org/download/?t=repo-config에 방문하여, OS 및 버전 선택

2) repository 설정

- 홈페이지에 있는대로 repo 설정을 넣는다.

 

cd /etc/yum.repos.d

vi MariaDB.repo

# MariaDB 10.6 RedHatEnterpriseLinux repository list - created 2023-10-25 05:54 UTC
# https://mariadb.org/download/
[mariadb]
name = MariaDB
# rpm.mariadb.org is a dynamic mirror if your preferred mirror goes offline. See https://mariadb.org/mirrorbits/ for details.
# baseurl = https://rpm.mariadb.org/10.6/rhel/$releasever/$basearch
baseurl = https://tw1.mirror.blendbyte.net/mariadb/yum/10.6/rhel/$releasever/$basearch
module_hotfixes = 1
# gpgkey = https://rpm.mariadb.org/RPM-GPG-KEY-MariaDB
gpgkey = https://tw1.mirror.blendbyte.net/mariadb/yum/RPM-GPG-KEY-MariaDB
gpgcheck = 1


yum clean all
yum repolist all

 

3) yum 설치

- MariaDB 10.6.15 버전 설치되는것 확인

yum install MariaDB-server MariaDB-client

systemctl status  mariadb

 


2. MariaDB 기본 설정(DB 기동 중 진행해야 함. mariadb-secure-installation)

 

- mariadb-secure-installation 명령어 실행

mariadb-secure-installation

(중략)

Enter current password for root (enter for none):(엔터)
OK, successfully used password, moving on...

(중략)

Switch to unix_socket authentication [Y/n] y
Enabled successfully!
Reloading privilege tables..
 ... Success!

(중략)

Change the root password? [Y/n] y
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
 ... Success!

(중략)

Remove anonymous users? [Y/n] y
 ... Success!

(중략)

Disallow root login remotely? [Y/n] y
 ... Success!

(중략)

Remove test database and access to it? [Y/n] y
 - Dropping test database...
 ... Success!
 - Removing privileges on test database...
 ... Success!

(중략)

Reload privilege tables now? [Y/n] y
 ... Success!

(중략)

- Mariadb 접속

mysql -u root -p
mariadb -u root -p <<< 이것도 가능


MariaDB [(none)]> status  <<<<< 상태 확인
--------------
mariadb  Ver 15.1 Distrib 10.6.15-MariaDB, for Linux (x86_64) using readline 5.1

Connection id:          15
Current database:
Current user:           root@localhost
SSL:                    Not in use
Current pager:          stdout
Using outfile:          ''
Using delimiter:        ;
Server:                 MariaDB
Server version:         10.6.15-MariaDB MariaDB Server
Protocol version:       10
Connection:             Localhost via UNIX socket
Server characterset:    latin1
Db     characterset:    latin1
Client characterset:    utf8mb3
Conn.  characterset:    utf8mb3
UNIX socket:            /var/lib/mysql/mysql.sock
Uptime:                 57 min 13 sec

Threads: 1  Questions: 30  Slow queries: 0  Opens: 21  Open tables: 14  Queries per second avg: 0.008

3. 

+ Recent posts