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

[MySQL] collation  (0) 2022.02.15
[MySQL] Safe update mode off  (0) 2020.11.10
블로그 이미지

uchacha

개발자 일지

,

안드로이드 클라이언트 모듈을 테스트하다가 Http Connection 에러가 나길래 봤더니

Emulator 자체에서 인터넷에 접속이 안됐다..

 

해결책은 DNS를 google public DNS인 8.8.8.8, 8.8.4.4로 설정하라던가..

애뮬레이터를 cold boot로 실행해보라던가..

cmd상에서 DNS를 8.8.8.8로 실행해보던가..

다 안돼서 안드로이드를 새로 깔고 다시 설정해도 안된다..

 

문제는 안랩 보안 프로그램에서 개인 방화벽에 qemu-system-x86_64.exe 가 차단되어 있었던 것 ㅜㅜ..

이틀동안 헤매고 해매서 찾아 감격해서 글을 올린다.

 

다른 분들은 이런 문제 있을 때 해당 사항도 확인해보시길.

블로그 이미지

uchacha

개발자 일지

,

- @참고 : https://ryanking13.github.io/2018/09/03/cmd-deafult-command.html

 

Windows cp949 인코딩 자동 변경하기

한글 Windows를 사용하다보면 종종 불편한 것이 기본 시스템 인코딩이 cp949로 설정되어 있다는 것이다.

ryanking13.github.io

Window cmd에서 한글이 깨질 때 시스템 인코딩(cp949)을 변경

이를 해결하기 위해

1. Windows cmd에 다음 명령어 치기

chcp 65001

 

2. 자동으로 수행되게 하기 위해 레지스트리 항목 변경

# 전체 유저에게 영향을 주고 싶다면
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Command Processor

# 한 유저에게만 영향을 주고 싶다면
HKEY_CURRENT_USER\SOFTWARE\MICROSOFT\Command Processor

Autorun 항목을 추가(우클릭 후 문자열 추가)하면 명령 프롬프트가 실행되었을 때 특정 명령어가 자동으로 실행되게 할 수 있다.

블로그 이미지

uchacha

개발자 일지

,

'HTTP' 카테고리의 다른 글

[Web, CORS] SameSite Cookie 란  (0) 2022.02.08
[rfc] User-Agent란  (0) 2019.12.24
블로그 이미지

uchacha

개발자 일지

,

- @참고 : https://cholchori.tistory.com/2033

 

사전준비

openssl

 

방법

openssl x509 -inform der -in signCert.der -out signCert.pem
openssl pkcs8 -inform der -in signPri.key -out signPri.pem
openssl pkcs12 -export -in signCert.pem -inkey signPri.pem -inkey signPri.pem -out mycert.pfx
블로그 이미지

uchacha

개발자 일지

,

- @참고 : http://www.songtory.com/post/001007/1/246

- @참고2 : https://www.securesign.kr/guides/SSL-Certificate-Convert-Format

- @참고3 : https://stackoverflow.com/questions/34156938/openssl-hangs-during-pkcs12-export-with-loading-screen-into-random-state

 

사전 준비

openssl

 

RSA

1. key파일을 만든다.(2048 bit)

openssl genrsa -out server.key 2048

2. csr을 생성(생성시 지역 등을 물어봄. 적당히 입력)

openssl req -new -key server.key -out server.csr

3. 인증서 만들기(유효기간 365일짜리)

openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

 

PFX

1. crt와 key파일을 합쳐서 pfx 파일로 만드는법

openssl pkcs12 -export -in server.crt -inkey server.key -out server.pfx

 

참고사항

윈도우에서 openssl pkcs12 export 시 멈춤현상을 해결하는 방법

  • Windows console에서 터미널 입/출력에 문제가 있을 수 있으므로 유닉스 터미널 동작이 필요한 경우 winpty가 도움이 될 수 있다.
winpty bash
블로그 이미지

uchacha

개발자 일지

,

- @참고 : https://refactoring.guru/design-patterns/facade

 

Facade

Intent Facade is a structural design pattern that provides a simplified interface to a library, a framework, or any other complex set of classes. Problem Imagine that you must make your code work with a broad set of objects that belong to a sophisticated l

refactoring.guru

🙌 취지

퍼사드는 라이브러리, 프레임워크, 또는 기타 복잡한 클래스 집합에 심플한 인터페이스를 제공하는 구조적 디자인 패턴입니다.

🤔 문제점

복잡한 라이브러리나 프레임워크에 속한 광범위한 객체 집합에 대해 코드를 작동시켜야 한다고 상상해보십시오. 일반적으로, 당신은 모든 객체를 초기화해야하고, 의존성을 추적하고, 올바른 순서로 메소드를 실행하는 등등을 합니다.

그 결과, 당신의 클래스에 대한 비즈니스 로직은 타사 클래스의 구현 세부사항과 밀접하게 결합되고, 이는 이해와 유지를 어렵게 합니다.

😊 해결책

퍼사드는 많은 동적 부분을 포함하는 복잡한 서브시스템에 단순한 인터페이스를 제공하는 클래스입니다. 퍼사드는 서브시스템을 직접 사용하는 것과 비교하여 제한된 기능을 제공할 수 있습니다. 그러나 클라이언트가 실제로 관심을 갖는 기능만 포함합니다.

수십가지 기능을 갖는 복잡한 라이브러리와 앱을 통합해야 할 필요가 있을 때 퍼사드를 사용하는 것이 편리하지만, 약간의 기능이 필요합니다.

예를 들어, 고양이에 대한 짧은 재밌는 동영상을 소셜 미디어에 업로드하는 앱은 전문적인 비디오 변환 라이브러리를 사용할 수 있습니다. 그러나 필요한 모든 것은 encode(filename, format)이라는 단일 메소드를 가지는 클래스입니다. 이러한 클래스를 생성하고 동영상 변환 라이브러리와 연결하면, 첫번째 퍼사드가 됩니다.

🚗 실세계에 비유

전화로 주문하기

상점에 전화를 걸어 전화 주문을 하면, 운영자는 상점의 모든 서비스와 부서에 대한 퍼사드(정면)입니다. 운영자는 주문 시스템, 지불 게이트웨이 및 다양한 배송 서비스에 대한 간단한 음성 인터페이스를 제공합니다.

🔦구조

1. Facade는 서브시스템 기능의 특정 부분에 편리하게 접근할 수 있도록 합니다. 고객의 요청을 지시하는 위치와 모든 동적 부품을 작동하는 방법을 압니다.

2. 추가적 퍼사드(Additional Facade) 클래스는 또다른 복잡한 구조를 만들 수 있는 관련 없는 기능으로 단일 퍼사드를 오염하는 걸 방지하기 위해 생성될 수 있습니다. 추가 퍼사드는 클라이언트와 다른 퍼사드 모두에게 사용될 수 있습니다.

3. 복잡한 서브시스템(Complex Subsystem)은 수십의 다양한 객체로 구성됩니다. 이들 모두가 의미있는 일을 하게 하려면, 올바른 순서로 객체를 초기화하고 데이터를 적절한 포맷으로 제공하는 것과 같은 서브시스템의 구현 세부사항을 자세히 살펴봐야 합니다.

 서브시스템 클래스는 퍼사드의 존재를 인식하고 있지 않습니다. 이들은 시스템 내에서 작동하고 서로 직접 작업합니다.

# 짜가코드

이 예제에서, 퍼사드 패턴은 복잡한 비디오 변환 프레임워크와의 상호작용을 단순화합니다.

단일 퍼사드 클래스 내에서 여러 종속성을 격리하는 예제

코드를 수십의 프레임워크 클래스와 직접 작동시키는 대신, 해당 기능을 캡슐화하고 코드의 나버지 부분에서 숨기는 퍼사드 클래스를 생성합니다. 이 구조는 또한 향후 버전의 프레임워크로 업그레이드 하거나 다른 것과 대체하는 노력을 최소화하는걸 돕습니다. 당신이 앱에서 바꿀 필요가 있는 것은 퍼사드 메소드의 구현뿐입니다.

//이것은 복잡한 타사 비디오 변환 프레임워크 클래스의 일부입니다. 코드를 제어하지 않으므로 단순화할 수 없습니다.

class VideoFile
// ...

class OggCompressionCodec
// ...

class MPEG4CompressionCodec
// ...

class CodecFactory
// ...

class BitrateReader
// ...

class AudioMixer
// ...


//프레임워크의 복잡성을 단순한 인터페이스 뒤에 숨기기 위해 퍼사드 클래스를 만듭니다. 기능과 단순성 간의 균형을 유지합니다.
class VideoConverter is
	method convert(filename, format):File is
    	file = new VideoFile(filename)
        sourceCodec = new CodeFactory.extract(file)
        if (format == "mp4")
        	destinationCodec = new MPEG4CompressionCodec()
        else
        	destinationCodec = new OggCompressionCodec()
		buffer = BitrateReader.read(filename, sourceCodec)
        result = BitrateReader.convert(buffer, destinationCodec)
        result = (new AudioMixer()).fix(result)
        return new File(result)
        
//어플리케이션 클래스는 복잡한 프레임워크에서 제공하는 10억개의 클래스에 의존하지 않습니다. 또한, 프레임워크를 전환하기로 결정한다면, 퍼사드 클래스만 다시 작성하면 됩니다.
class Application is
	method main() is
    	converter = new VideoConverter()
        mp4 = convertor.convert("funny-cats-video.ogg", "mp4")
        mp4.save()

💡 적용

  • 복잡한 서브시스템에 대한 제한적이지만 간단한 인터페이스가 필요한 경우 퍼사드 패턴을 사용합니다.
    • 종종, 서브시스템은 시간이 지남에 따라 더욱 복잡해집니다. 디자인 패턴을 적용하더라도 일반적으로 더 많은 클래스를 생성하게 합니다. 서브시스템은 다양한 상황에서 더 유연하고 재사용하기 쉬워질 수 있지만, 클라이언트에서 요구하는 구성과 상용구 코드의 양은 점점 더 커지고 있습니다. 퍼사드는 클라이언트의 요구사항에 맞는 서브시스템의 가장 많이 사용되는 기능에 대한 바로가기를 제공하여 이러한 문제를 해결하려 합니다.
  • 서브시스템을 계층으로 구조화하려는 경우 퍼사드를 사용합니다.
    • 서브시스템의 각 단계에 대한 진입점을 정의하는 퍼사드를 작성하세요. 퍼사드를 통해서만 통신하게 함으로써 다중 서브시스템 간의 커플링을 줄일 수 있습니다.
    • 예를 들어, 동영상 변환 프레임워크로 돌아가 보겠습니다. 비디오와 오디오 관련의 두 계층으로 나눌 수 있습니다. 각 계층에 대해, 퍼사드를 생성하고 각 계층의 클레스가 해당 퍼사드를 통해 서로 통신하도록 할 수 있습니다. 이 방법은 중재자 패턴과 매우 유사합니다.

📋 구현 방법

  1. 기존 서브시스템이 제공하는 것보다 더 간단한 인터페이스를 제공할 수 있는지 체크합니다. 인터페이스가 클라이언트 코드를 많은 서브시스템의 클래스와 독립적으로 만들고 있으면 올바른 길을 가고 있습니다.
  2. 새 퍼사드 클래스에서 이 인터페이스를 선언하고 구현합니다. 퍼사드는 호출을 클라이언트 코드로부터 서브시스템의 적절한 객체로 리다이렉트해야 합니다. 퍼사드는 클라이언트 코드가 이미 수행하지 않는 한 서브시스템을 초기화하고 추가 수명 주기를 관리해야 합니다.
  3. 패텀의 이점을 최대한 활용하려면 모든 클라이언트 코드가 퍼사드를 통해서만 서브시스템과 통신하도록 하세요. 그러면 클라이언트 코드는 서브시스템 코드의 변경 사항으로 부터 보호됩니다. 예를 들어, 서브시스템이 새 버전으로 업그레이드 되면 퍼사드의 코드만 수정하면 됩니다.
  4. 퍼사드가 너무 커지면, 동작 부분을 새롭고 세련된 퍼사드 클래스로 추출하는 걸 고려합니다.

⚖ 장단점

✔ 서브시스템의 복잡성으로 부터 코드를 분리할 수 있습니다.

❌ 퍼사드는 앱의 모든 클래스와 연결된 신 객체가 될 수 있습니다.

🐱‍🏍 다른 패턴과의 관계

  • 퍼사드는 기존 객체에 대한 새 인터페이스를 정의하는 반면, 어댑터는 기존 인터페이스를 사용 가능하게 만듭니다. 어댑터는 보통 한 객체를 감싸는 반면, 퍼사드는 객체의 전체 서브시스템에서 작동합니다.
  • 추상 팩토리는 클라이언트 코드에서 서브시스템의 객체가 생성되는 방식만 숨기려는 경우 퍼사드의 대체로 쓸 수 있습니다.
  • Flyweight는 많은 작은 객체를 만드는 방법을 보여주는 반면, 퍼사드는 전체 서브시스템을 나타내는 단일 객체를 만드는 방법을 보여줍니다.
  • 퍼사드중재자는 비슷한 작업을 수행합니다. 강하게 결합된 클래스들 간의 콜라보레이션을 조직하려 합니다.
    • 퍼사드는 단순화된 인터페이스를 정의하지만, 새로운 기능을 도입하지는 않습니다. 서브시스템 자체는 퍼사드를 인식하지 못합니다. 서브시스템 내 객체는 직접 통신할 수 있습니다.
    • 중재자는 시스템 구성 요소 간의 통신을 중앙화합니다. 구성 요소는 중개자 객체에 대해서만 알고 있으며 직접 통신하지 않습니다.
  • 퍼사드 클래스는 대부분의 경우 단일 파사드 오브젝트로 충분하기 때문에 종종 싱글톤으로 변환될 수 있습니다.
  • 퍼사드는 복잡한 객체를 버퍼링하고 자체적으로 초기화한다는 점에서 프록시와 유사합니다. 퍼사드와 달리, 프록시는 서비스 객체와 동일한 인터페이스를 가지고 있어 상호 교환이 가능합니다.

</> 코드 예제

복잡한 동영상 변환 라이브러리에 대한 간단한 인터페이스

이 예제에서, 퍼사드는 복잡한 동영상 변환 프레임워크와의 통신을 단순화 합니다.

퍼사드는 프레임워크의 올바른 클래스를 구성하고 올바른 형식으로 결과를 검색하는 모든 복잡성을 처리하는 단일 메소드를 단일 클래스에 제공합니다.

📁 some_complex_media_library: Complex video conversion library

📄 some_complex_media_library/VideoFile.java

package some_complex_media_library;

public class VideoFile {
	private String name;
	private String codecType;
	
	public VideoFile(String name) {
		this.name = name;
		this.codecType = name.substring(name.indexOf(".") + 1);
	}
	
	public String getCodecType() {
		return codecType;
	}
	
	public String getName() {
		return name;
	}
}

📄 some_complex_media_library/Codec.java

package some_complex_media_library;

public interface Codec {
}

📄 some_complex_media_library/MPEG4CompressionCodec.java

package some_complex_media_library;

public class MPEG4CompressionCodec implements Codec {
	public String type = "mp4";
}

📄 some_complex_media_library/OggCompressionCodec.java

package some_complex_media_library;

public class OggCompressionCodec implements Codec {
	public String type = "ogg";
}

📄 some_complex_media_library/CodecFactory.java

package some_complex_media_library;

public class CodecFactory {
	public static Codec extract(VideoFile file) {
		String type = file.getCodecType();
		if (type.equals("mp4")) {
			System.out.println("CodecFactory: extracting mpeg audio...");
			return new MPEG4CompressionCodec();
		}
		else {
			System.out.println("CodecFactory: extracting ogg audio...");
			return new OggCompressionCodec();
		}
	}
}

📄 some_complex_media_library/BitrateReader.java

package some_complex_media_library;

public class BitrateReader {
	public static VideoFile read(VideoFile file, Codec codec) {
		System.out.println("BitrateReader: reading file...");
		return file;
	}
	
	public static VideoFile convert(VideoFile buffer, Codec codec) {
		System.out.println("BitrateReader: writing file...");
		return buffer;
	}
}

📄 some_complex_media_library/AudioMixer.java

package some_complex_media_library;

import java.io.File;

public class AudioMixer {
	public File fix(VideoFile result) {
		System.out.println("AudioMixer: fixing audio...");
		return new File("tmp");
	}
}

📁 some_complex_media_library: Complex video conversion library

📄 some_complex_media_library/VideoFile.java: Facade provides simple interface of video conversion

package facade;

import java.io.File;

import some_complex_media_library.AudioMixer;
import some_complex_media_library.BitrateReader;
import some_complex_media_library.Codec;
import some_complex_media_library.CodecFactory;
import some_complex_media_library.MPEG4CompressionCodec;
import some_complex_media_library.OggCompressionCodec;
import some_complex_media_library.VideoFile;

public class VideoConversionFacade {
	public File convertVideo(String fileName, String format) {
		System.out.println("VideoconversionFacade: conversion started.");
		VideoFile file = new VideoFile(fileName);
		Codec sourceCodec = CodecFactory.extract(file);
		Codec destinationCodec;
		if (format.contentEquals("mp4")) {
			destinationCodec = new MPEG4CompressionCodec();
		} else {
			destinationCodec = new OggCompressionCodec();
		}
		VideoFile buffer = BitrateReader.read(file, sourceCodec);
		VideoFile intermediateResult = BitrateReader.convert(buffer, destinationCodec);
		File result = (new AudioMixer()).fix(intermediateResult);
		System.out.println("VideoConversionFacade: conversion completed.");
		return result;
	}
}

📄 some_complex_media_library/Codec.java

import java.io.File;

import facade.VideoConversionFacade;

public class Demo {
	public static void main(String[] args) {
		VideoConversionFacade converter = new VideoConversionFacade();
		File mp4Video = converter.convertVideo("youtubevideo.ogg", "mp4");
		// ...
	}
}

📄 OutputDemo.txt: Execution result

VideoconversionFacade: conversion started.
CodecFactory: extracting ogg audio...
BitrateReader: reading file...
BitrateReader: writing file...
AudioMixer: fixing audio...
VideoConversionFacade: conversion completed.
블로그 이미지

uchacha

개발자 일지

,

 

윈도우 10에서 톰캣을 실행시키면 별도의 창으로 server의 로그가 뜨고 종료시키면 흔적도 없이 사라집니다.

CentOS와 같은 타 운영체제는 catalina.out으로 server의 로그을 확인할 수 있는데 window는 zip으로 다운 후 압축해재하였을 때 따로 catalina.out 파일이 존재하지 않습니다.

이를 해결하기 위하여 다음과 같은 일을 하였습니다.

실패한 방법

- @참고 : https://stackoverflow.com/questions/3491574/there-is-no-catalina-out

더보기

bach file 'start&log.bat'

catalina run > ..\logs\catalina.out 2<&1

이 파일을 작성 후 startup.bat 하기 전에 start&log.bat을 먼저 실행합니다.

 

**

...

05-Mar-2020 17:26:12.581 ?뺣낫 [main] org.apache.coyote.AbstractProtocol.start Starting ProtocolHandler ["ajp-nio-8011"] 

05-Mar-2020 17:26:12.591 ?뺣낫 [main] org.apache.catalina.startup.Catalina.start Server startup in 16313 ms 

05-Mar-2020 17:26:12.593 ?ш컖 [main] org.apache.catalina.core.StandardServer.await StandardServer.await: create[localhost:8007]: 
        java.net.BindException: Address already in use: JVM_Bind 
                at java.net.DualStackPlainSocketImpl.bind0(Native Method) 
                at java.net.DualStackPlainSocketImpl.socketBind(DualStackPlainSocketImpl.java:106) 
                at java.net.AbstractPlainSocketImpl.bind(AbstractPlainSocketImpl.java:387) 
                at java.net.PlainSocketImpl.bind(PlainSocketImpl.java:190) 
                at java.net.ServerSocket.bind(ServerSocket.java:375) 
                at java.net.ServerSocket.(ServerSocket.java:237) 
                at org.apache.catalina.core.StandardServer.await(StandardServer.java:421) 
                at org.apache.catalina.startup.Catalina.await(Catalina.java:776) 
                at org.apache.catalina.startup.Catalina.start(Catalina.java:722) 
                at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
                at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
                at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
                at java.lang.reflect.Method.invoke(Method.java:498) 
                at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:353) 
                at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:493) 

05-Mar-2020 17:26:12.608 ?뺣낫 [main] org.apache.coyote.AbstractProtocol.pause Pausing ProtocolHandler ["http-nio-8082"]

다음과 같은 에러를 뱉어내며 창이 꺼집니다.

이 에러는 shutdown.bat에서 run 시켰던 tomcat이 안 꺼지면서 나는 에러인 것으로 추측되며,

다시 시도해 봤을 때 기록되는 것은 내가 원하는 server의 기록이 아닌 순수 catalina가 돌면서 생기는 기록인 듯 합니다.

 

다른 방법

1. git bash로 ./start.sh 실행

2. tail -f catalina.out으로 ../logs/catalina.out 확인

 

다른 방법 ?? 20-05-26일 시도해보니 순수 catalina 로그만 찍힘

- @참고 : https://coderanch.com/t/87187/application-servers/generate-catalina-logger-tomcat-server

startup.bat에 다음과 같이 수정 및 추가합니다.

1. start → run 수정

2. >> ../logs/catalina.out 추가

startup.bat

call "%EXECUTABLE%" run %CMD_LINE_ARGS% >> ../logs/catalina.out 2>&1

* 창에는 아무 내용도 뜨지 않고 관련기록은 모두 catalina.out에서 읽을 수 있습니다.

* 2>&1을 제거하면 창에는 시작시 로그 파일 및 tomcat 실행에 관련한 log가 뜨고 server 로그는 catalina.out에서 볼 수 있습니다.

 

다른 방법 2

- @참고 : https://coderanch.com/t/87187/application-servers/generate-catalina-logger-tomcat-server

톰캣 '.exe' version을 설치합니다.

 

블로그 이미지

uchacha

개발자 일지

,