환경 

centOS7.5 

MariaDB 

 

목표

B테이블과 연관관계가 있는 A테이블을 삭제하고 싶음 

 

문제 상황 

MariaDB [bim_library]> delete from library_info where library_no between 1 and 50;
ERROR 1451 (23000): Cannot delete or update a parent row: 
a foreign key constraint fails 
(`bim_library`.`tag`, CONSTRAINT `FK2tk1sqt8jfmgqn7st8l73214` 
FOREIGN KEY (`library_no`) REFERENCES `library_info` (`library_no`))

 

해결 과정 

외래키를 해제해주는 명령어가 있었음 

set foreign_key_checks = 0;

테이블 드랍 하고, 

 

반드시 다시 외래키를 체크하는 옵션을 켜줘야 한다. 

set foreign_key_checks = 1;
728x90

@ColumnDefault

ddl-auto 조건이 create 또는 create-drop일 때

즉, 테이블을 처음 생성할 때 컬럼 기본값 제약조건을 정의해준다. 

컬럼에 붙이는 애노테이션.

 

Identifies the DEFAULT value to apply to the associated column via DDL.

DDL에 적용되는 기본 정의 라고 되어있다

Annotation Type ColumnDefault  hibernate javadoc 

 

@DynamicInsert

null이 아닌 값만 insert 해준다. 

만약, null이 들어온 경우, 제약조건에 명시된 기본값이 있다면 그것이 적용되어 insert 된다. 

테이블에 붙이는 애노테이션.

 

Annotation DynamicInsert hibernate userguide 


참고한 글 

JPA @ColumnDefault에 대한 오해, 컬럼 default 적용하기

jpa insert 시 default 값 적용 

테이블에 default 값 적용

728x90

목표 

pk로 엔티티를 조회 해온다. 

조회한 엔티티를 복제한다. 일부 내용만 바꾸고 새로운 pk를 가진 엔티티로써 저장한다. 

즉, 4번 pk 엔티티를 조회하여 복제한다. (4번 엔티티의 내용은 변경하지 않는다. )

일부 내용만 바꾼 후, 5번 엔티티로써 저장한다. 

찾아본 내용 

"jpa entity copy"로 구글링 했는데 stackoverflow의 How to clone a JPA entity 글이 있었다.

 "EntityManager.detach() 를 쓰세요." 

 

entityManager.detach()

엔티티 매니저가 관리하는 영속성 컨텍스트에서 분리된 상태가 된다. 

즉, 더티 체킹(변경 감지)의 대상에서 제외되는 것이다. 

준영속 상태로 만든 다음 데이터를 세팅하고, 다시 엔티티 매니저의 관리대상이 되도록 persist() 하라는 답변이었다. 

 

Member엔티티의 PK를 FK로 사용하는 엔티티의 정보까지 바뀌도록 신경써야 해서 삽질이 길었다. 

Member엔티티를 persist() 하기 전에,  FK로 연관된 엔티티들을 일일이 set해줬다. 

Member 엔티티와 연관관계에 있는 엔티티들은 전부 Cascade.Type All로 설계했기 때문에 다 연결되어 있었기 때문이다. 

 

수정한 예시 코드다. 

아래와 같은 흐름으로 수정하여 해결할 수 있었다. 

Long targetId = 1L;

Member oldMember = em.find(Member.class, targetId);
Hobby oldHobby = oldMember.getHobby();

em.detach(oldMember); // 준영속 상태로 만든다. (JPA가 관리하지 않는 객체가 된다)
oldMember.setName("minzy");
oldMember.setId(targetId + 1L); // PK를 1증가시킨다 

oldMember.setHobby(oldHobby); // 연관관계에 있는 엔티티 정보도 set해야 한다. 

em.persist(oldMember); // 영속성 컨텍스트의 1차 캐시에 올라가도록, 영속 상태로 만든다.

참고한 글 

JPA구동 방식

영속성 컨텍스트와 플러시 이해하기

 

[JPA] 영속성 컨텍스트와 플러시 이해하기

영속성 컨텍스트 JPA를 공부할 때 가장 중요한게 객체와 관계형 데이터베이스를 매핑하는 것(Object Relational Mapping) 과 영속성 컨텍스트를 이해하는 것 이다. 두가지 개념은 꼭 알고 JPA를 활용하자.

ict-nroo.tistory.com

 

728x90

 

mac에는 파이썬 2.7이 기본 설치되어 있다. 

 

최신 파이썬 3.10 을 쓰고 싶어서 파이썬을 설치한다.

brew install python

파이썬 설치 경로를 확인한다. 

ls -l /usr/local/bin/python*

파이썬의 기본 symlink를 python3로 바꾼다. 

sudo ln -s -f /usr/local/bin/python3.10 /usr/local/bin/python

뭐지. 아직도 파이썬이 2.7

 

이 방법이 안먹혀서 zshrc의 python 명령이 python3을 가리키도록 변경했다. 

홈디렉토리에 zshrc 라는 설정파일이 있다. 

여기에 alias python="python3" 라는 별명을 붙여준다. 

즉, python을 입력하면 python3라고 인식하게 한다. 

source 명령은 스크립트 파일 속 내용을 실행하는 명령이다. 

cd ~ // 홈디렉토리로 이동 
echo alias python="python3" > ~/.zshrc 

//bash 이용자는 .bash_profile

source ~/.zshrc 
python -V

 

파이썬 버전을 다시 확인해보자. python 버전을 확인하면 python3 라고 잘 뜬다. 

zshrc 설정파일 내용을 확인하면 아래와 같다. 별칭을 붙인 것이다. 

 


참고 블로그

Mac OS python 기본 버전 변경하기

How to set Python3 as a defalut python version on MacOS

728x90

객체지향 설계 5원칙 - SOLID

SOLID는 개념이다.
객체 지향 프로그램을 구성하는 속성, 메서드, 클래스, 객체, 패키지, 모듈, 라이브러리, 프레임워크 등 다양한 곳에 적용된다.

SOLID 원칙에 대한 간단한 예제를 보며 이해해보자.

단일 책임 원칙 Single Responsibility Principle

“어떤 클래스를 변경해야 할 이유는 오직 하나뿐이어야 한다.” -로버트 C.마틴

하나의 클래스는 하나의 책임만 가져야 햔다.

예시) 속성이 SRP를 지키지 않은 경우,

class 사람 { 
    String 군번; 
… }

사람 로미오 = new 사람();
사람 줄리엣 = new 사람();

줄리엣.군번 = "15723491"; <- ??? 

사람 클래스를 여자 클래스와 남자 클래스로 분할하자.
단일 책임 원칙을 적용하는 것이다.

SRP를 지키지 않으면, if문을 불필요하게 많이 쓰게 된다.

데이터베이스에서도 테이블을 정규화하는 과정이 있다.
테이블과 필드에 대한 단일 책임 원칙의 적용이라고 할 수 있다.

객체지향 4대 특성 중, 단일 책임 원칙과 가장 관련 깊은 것은 뭘까?
추상화가 아닐까.
애플리케이션의 경계를 정하고, 추상화를 통해 클래스를 선별하고,
속성과 메서드를 설계할 때 반드시 SRP를 고려하는 습관을 들이자.

개방 패쇄 원칙 Open Closed Principle

“소프트웨어 엔티티(클래스, 모듈, 함수 등)은 확장에 대해서는 열려있어야 하지만, 변경에 대해서는 닫혀 있어야 한다” -로버트 C.마틴

—> 자신의 확장에는 열려있고, 주변의 변화에 대해서는 닫혀 있어야 한다.

JDBC를 예로 들어보자.

JDBC를 사용하는 클라이언트는 DB가 Oracle에서 Mysql로 바뀌더라도, Connection을 수정할 필요가 없다.
DB를 교체할 때, 자바 애플리케이션은 JDBC인터페이스라는 완충 장치로 변화에 영향을 받지 않는다.

자바를 예로 들어보자.

자바 개발자가 작성한 코드가 윈도우에서 구동될 지, 리눅스에서 구동될 지 모른다.
신경 안써도 된다.
각 운영체제별 JVM이 윈도우에 맞게, 리눅스에 맞게 바이너리 코드를 번역해준다.

개발자가 작성한 코드는 운영체제의 변화에 닫혀있다.
각 운영체제별 JVM은 확장에 열려있는 구조가 되는 것이다.
자바 코드와 운영체제별 JVM 간에 목적 파일이라는 완충 장치가 있는 것이다.

리스코프 치환 원칙 Liskov Substitution Principle

“서브 타입은 언제나 자신의 기반 타입(base type)으로 교체할 수 있어야 한다. ” -로버트 C.마틴

상속을 떠올려 보자.
상속은 계층도/조직도가 아니다. 분류도를 떠올려야 한다.
하위 클래스 is a kind of 상위 클래스 ex)참새는 새의 하나의 종류다.
구현 클래스 is able to 인터페이스 ex) 구현 분류는 인터페이스 할 수 있어야 한다.

참고 ) 인터페이스 할 수 있어야 한다. 의 의미?
AutoCloseable - 자동으로 닫힐 수 있어야 한다
Cloneable - 복제할 수 있어야 한다

“하위 클래스의 인스턴스는 상위형 객체 참조 변수에 대입해 상위 클래스의 인스턴스 역할을 하는 데 문제가 없어야 한다. “

고래와 박쥐는 포유류에 포함된다.
참새와 비둘기는 조류에 포함된다.
포유류와 조류는 동물에 포함된다.

고래는 포유류의 역할을 할 수 있다.
참새는 조류 역할을 할 수 있다.
참새는 동물의 역할을 할 수 있다.

결국, 리스코프 치환 원칙은 상속의 특성을 바르게 활용하면 얻게 되는 것이다.

인터페이스 분리 원칙 Interface Segregation Principle

단일 책임 원칙을 떠올려 보자.
하나의 클래스는 하나의 역할만 갖도록 했다.

의존 역전 원칙 Dependency Inversion Principle

작성중.

728x90

1. 목표 

centos에 아파치 설치하기 (환경은 centos 7.5)

아파치 포트 변경 

아파치 서비스 시작하고, 정상 시작됬는지 확인하기 

 

2. 문제 내용  

아파치 서비스가 안켜진다. 에러 내용은 Permission denied 

 

3. 원인 및 해결 과정 

SELinux 보안 정책을 변경함 

 


아파치 설치 

yum 업데이트하고, httpd를 설치한다. 

rpm -qa | grep httpd
yum -y update
yum -y install httpd
httpd -v

 

아파치 설정파일 열고 포트 변경 

 

설정파일 위치 

/etc/httpd/conf/httpd.conf

8088 로 바꾸고 저장했다. 

아파치 서비스 재시작

service httpd start

 

Redirecting to /bin/systemctl start httpd.service 리다이렉팅 왜 될까 ? 

 

service start 명령을 실행하면, 

Redirecting to /bin/systemctl start httpd.service  되는데, 

service 는 CentOS 6이전 버전 명령이고, 

systemctl 은 CentOS 7이후 버전 명령이다. 예전 버전 명령을 치더라도 redirecting 해서 systemctl로 실행시킨다는 것이다. 

 

netstat -tulpn으로 확인 

네트워크 인터페이스, 라우팅 테이블, 네트워크 접속 정보를 볼 수 있는 netstat 

옵션에 tulpn 을 줫는데, 

t == tcp 

u == udp 

l == LISTEN중인것 

p == PID/프로그램 이름 

n == port number 

8088 포트로 LISTEN 중인 apache가 없다..! 

 

 

아파치 서비스를 켜고 제대로 켜졌는지 확인하는데, Permission error 가 나면서 안켜진다. 

systemctl status httpd.service -l

Permission denied: AH00072 

semanage를 이용하여 SELinux 설정을 변경한다. 

SELinux 동작모드는 3가지가 있다 

enforce, permissive, disable

centos 설치하면 defalut로 enforce 모드다.

setenforce 0 명령으로 permissive로 변경한다. 

setenforce 0 

service httpd start

서비스 정상 실행중 

 

만약, centos에서 semanage가 없으면 설치한다.

yum install policycoreutils-python

참고 포스팅

CentOS SELinux 설정 및 해제하기

아파치(Httpd) Permission Denied 오류 처리 

netstat 명령 

CentOS systemctl 과 service 

728x90

'일상 > Today I Learn(TIL)' 카테고리의 다른 글

Mac 에서 Python 버전 변경  (1) 2021.11.10
객체지향 설계 5원칙 - SOLID  (0) 2021.11.10
자바의 객체 지향 키워드와 연산자  (0) 2021.11.08
HTTP 기본  (0) 2021.11.05
2020-06-22 TIL  (0) 2020.06.22

+ Recent posts