반응형
반응형
// const printSimply = function () {console.log('you can make function simply!');}
const printSimply = () => console.log('you can make function simply!');

// const add = function (a, b) {
//     console.log(a + b);
//     console.log("end");
// }

const add = (a, b) => {
    console.log(a + b);
    console.log("end");
}

printSimply();
add(5, 4);
반응형
반응형
// logical operation
console.log('null == undefined ? ' + (null == undefined)); // true
console.log('null === undefined ? ' + (null === undefined)); // false
console.log('0 == false ? ' + (0 == false)); // true
console.log('0 === false ? ' + (0 === false)); // false
console.log('"" === false ? ' + ('' == false)); // true
console.log('"" === false ? ' + ('' === false)); // false

null == undefined == 0 == '' == false

 

반응형
반응형

📝Object (객체)

var book ={
	title : "채식주의자",
	author : "한강",
	price : "120000"
}

console.log(book.title); // 채식주의자

var book =[
	{
		title : "채식주의자",
		author : "한강",
		price : "120000"
	},
	{
	title : "육식주의자",
	author : "두강",
	price : "130000"
	}	
] // 배열 + 객체



console.log(book[0].title); // 채식주의자
console.log(book[1].title); // 육식주의자

// 객체

자바스크립트는 객체를 지정할 수 있고 속성 : 속성값으로 이루어져있습니다. 또한 배열로 여러개를 만들 수도 있습니다.

 

// Object (you can change inner value even if const)
const person  = {name : 'smith', age : 20};
console.log(`name : ${person.name}, age : ${person.age}`);
person.name = 'hommer'
console.log(`name : ${person.name}, age : ${person.age}`);

 

 

값에 직접 접근해 해당 내용의 값을 바꿀수도 있습니다.

 

📝Object Key를 변수로 할당하기 [Computed property]

// Computed property
let a = 'age';
const user1 = {
    name : 'Mike',
    // age : 30
    [a] : 30 // "키"에 변수를 할당할 수 있다
}
console.log(user1); //{ name: 'Mike', age: 30 }

const user2 = {
    [1 + 4] : 5,
    ["안녕" + "하세요"] : "Hello"
}

console.log(user2); // { '5': 5, '안녕하세요': 'Hello' }

 

📝Object 복사하기 (잘못된 버전) [주소복사]

const user = {
    name : 'Mike',
    age : 30
}
const cloneUser = user; // 주소 복사

/** 값 변화 **/
cloneUser.name = "Bob";
user.age = 10;

console.log(`name : ${user.name}, user.age : ${user.age}`);           // name : Bob, user.age : 10
console.log(`name : ${cloneUser.name}, user.age : ${cloneUser.age}`); // name : Bob, user.age : 10

그냥 = 으로 퉁쳐버리면 값이 복사가 되는게 아니라 주소가 복사됩니다. 그래서 서로에게 영향을 끼치기 때문에 생각한대로 프로그램이 안 돌아갈 수 있습니다.

 

 

📝Object 복사하기 [값 복사]

const user = {
    name : 'Mike',
    age : 30
}
const realCloneUser = Object.assign({}, user);

realCloneUser.name = "Bob";
user.age = 10;

console.log(`name : ${user.name}, user.age : ${user.age}`);                   // name : Mike, user.age : 10
console.log(`name : ${realCloneUser.name}, user.age : ${realCloneUser.age}`); // name : Bob, user.age : 30

Object.assign( ${기존 객체 값 [없을 시 {} 빈 값]}, ${복사할 값}을 이용해 값을 복사할 수 있습니다

 

📝기존 Object에 값 추가 및 덮어씌우기(overwrtie) 및 객체 합치기

const user = {
    name : 'Mike',
    age : 30
}

/** --- Clone Json Object [add] --- **/
const cloneUser1 = Object.assign({gender:'male'}, user); // 복제 + 원하는 값 추가
console.log(cloneUser1); // { gender: 'male', name: 'Mike', age: 30 }


/** --- Clone Json Object [overwrite] --- **/
const cloneUser2 = Object.assign({name:'Bob'}, user); // 복제 + 원하는 값 추가
console.log(cloneUser2); // { gender: 'male', name: 'Mike', age: 30 }


/** --- Merge Json Object --- **/
const name =  {name : 'Mike'}
const age =  {age : 40}
const gender =  {gender : 'female'}

const mergeUser = Object.assign(user, age, gender);
console.log(mergeUser); // { name: 'Mike', age: 40, gender: 'female' }

Object.assign( ${합칠 객체}, ${합칠 객체} ...을 이용해 객체를 합칠 수 있습니다

 

📝Object Key, Value 추출하기

const user = { name: 'Mike', age: 40, gender: 'female' }


/** --- Extract Json Keys, Values --- **/
const keys = Object.keys(user);
const values = Object.values(user);
console.log(keys);   // [ 'name', 'age', 'gender' ]
console.log(values); // [ 'Mike', 40, 'female' ]


/** --- Extract Json Keys + Values --- **/
const entries = Object.entries(user);
console.log(entries); // [ [ 'name', 'Mike' ], [ 'age', 40 ], [ 'gender', 'female' ] ]

 

  • Object.keys( ${키를 추출할 객체} ) 을 이용해 객체의 키를 배열로 추출할 수 있습니다.
  • Object.keys( ${값을 추출할 객체} ) 을 이용해 객체의 값을 배열로 추출할 수 있습니다.
  • Object.entries( ${키와 값을 추출할 객체} ) 을 이용해 객체의 키,값을 배열로 추출할 수 있습니다.

 

🔗 참고 및 출처

https://www.youtube.com/watch?v=6NZpyA64ZUU&list=PLZKTXPmaJk8JZ2NAC538UzhY_UNqMdZB4&index=3

반응형
반응형
// use strict
// 1. 동적타입 언어를 정적타입 언어로 바꾼다 → you can debug 
// 2. 동적타입에 대한 처리를 안 한다 → system speed up 
'use strict'; 
// a = 6; // 'a is not defined' Error occured

 

반응형
반응형

 📝약타입

다른 타입으로 변환이 가능하며 심지어 암묵적으로 변화을 해주기도 한다

int a = 1;
float b = 1.1f;
float c = a + b;

 

📝강타입

다른 타입으로 변환이 금지 되었고 명시적으로 타입을 선언해줘야한다

int a = 1;
String b = "Hello"
String c = a + b;

 

 

📝MView

물리적으로 존재하는 테이블로 데이터가 일정 공간을 차지한다는 특징이 있습니다

MView는 특정 결과를 생성하는 쿼리가 자주 사용되거나 실행 시간이 많이 소요되는 조인이나 복잡한 SQL에 대한 성능을 향상시키기 위해 사용한다

기존의 뷰(View)와는 달리, MView는 실제 데이터를 저장하고 있어 해당 값을 빠르게 조회 데이터 웨어하우 (Data Warehouse)나 대규모 데이터베이스 환경에서 효과적으로 사용될 수 있습니다

 

📝Base64

 

데이터를 64진법으로 표현하는 방식으로 2^6 =64 → 6bit로 문자 한개를 표현한다 (이진데이터 → 텍스트 형식 변환)

6bit를 4개씩 모아 변환하는데 이 때문에 비는 공간이 발생한다 빈공간은 = 문자로 채운다

Base64로 인코딩시 데이터의 크기는 33%증가하게 된다.

 

 

UTF-8하고 인코딩하는게 비슷해보이지만 UTF-8의 경우 문자 인코딩에 특화되어있어서 HTML, 텍스트 파일, 문자에 대해서는 사용되지만 엑셀, 이미지와 같은 이진데이터의 경우 Base64를 사용해서 보낼 수 있다

 

  • UTF-8
    • 문자열 → UTF-8 인코딩 → 이진형태로 변환 후 데이터 전송 → 이진형태 디코딩 → UTF-8 디코딩 → 문자열
  • Base64 (엑셀파일 기준)
    • 엑셀 파일 (데이터 이진 형태) → Base64 인코딩 문자열 전송 (이진형태로 데이터를 안 보내도 전송할 수 있게 설계되어있음) → Base64 디코딩 → 이진형태 Content Type에 맞게 해독

 

 

📝CI(Continuous Integration) / CD(Continuous Delivery, Continuous Deployment)

CI/CD 개념은 소프트웨어 개발 생명주기를 자동화하고 가속화하여 효율성을 높이고 신속한 소프트웨어 제공 가능

많이 사용하는 제품으로 Jenkins가 있다

 

📝CI (Continuous Integration)

CI는 "지속적 통합"을 나타내며 소프트웨어 개발에서 발생할 수 있는 문제를 조기에 감지하고 해결하기 위한 개발 방법론으로 개발자들이 코드를 중앙 저장소에 푸시할 때마다 자동으로 빌드 및 테스트를 수행합니다 이를 통해 코드 변경 사항의 통합이 지속적으로 이루어지며, 팀 내에서 코드 품질을 높이고 오류를 조기에 발견할 수 있습니다

 

💗장점

  1. 코드 퀄리티 향상 → 반드시 유닛테스트가 필요하기 때문에 그에 맞는 방향으로 개발해 실수를 줄인다.
  2. 즉각적인 버그 알림 → 유닛테스트 후 문제가 생긴 곳을 개발한 개발자에게 즉각 알림

 

📝CD (Continuous Delivery, Continuous Deployment)

CI를 기반으로 하는 지속적인 전달과 배포를 의미

  1. Continuous Delivery (CD):
    • Continuous Integration에서 온 테스트 및 빌드 단계를 통과한 코드를 자동으로 운영 환경에 배포 가능한 상태로 만듭니다
  2. Continuous Deployment (CD):
    • Continuous Integration에서 테스트 및 빌드를 통과한 코드가 자동으로 실제 운영 환경에 배포됩니다

 

📝쿠버네티스

컨테이너 관리 툴로서 나뉜 걸 배포하려고 할 때 수동으로 하나하나씩 올리기 힘들기 때문에 자동화 해주고 컨테이너를 모니터링해주고 죽은 즉시 바로 재시작을 시켜준다

컨테이너를 미리 카피하고 만들어 부하분산을 해준다.

 

 

 

 

 

🔗 참고 및 출처

https://www.youtube.com/watch?v=4oSS6xZ_fuM

https://velog.io/@jee/%EA%B0%95%ED%83%80%EC%9E%85%EA%B3%BC-%EC%95%BD%ED%83%80%EC%9E%85-%ED%98%B9%EC%9D%80-%EC%A0%95%EC%A0%81%ED%83%80%EC%9E%85%EA%B3%BC-%EB%8F%99%EC%A0%81%ED%83%80%EC%9E%85

 

반응형
반응형
`cat /home/search/template.txt` # `리눅스 명령어` → 백틱을 이용해 쉘스크립에서 리눅스 명령어 실행 가능
반응형
반응형
mappings=`echo ${mappings} | grep -v File | sed  -e "s/\t/ /g"`  # \t
mappings=`echo ${mappings} | grep -v File | sed  -e "s/\r/ /g"`  # \r
mappings=`echo ${mappings} | grep -v File | sed  -e "s/\ \+/ /g"` # 다중공백

# \t , \r, \+ 을 하나의 공백으로 변경
# sed -e /${현재내용}/${바꿀내용}/g

 

sed -i "s/기존문자/바꿀문자/g" 파일명

예) sed -i "s/abc/ttt/g" test.txt → text.txt의 abc문자열을 ttt로 변경한다.
반응형
반응형
@RequestMapping(value = "/downloadManual", method = RequestMethod.GET)
public void downloadManual(HttpServletResponse response) throws Exception {

    FileInputStream fileInputStream = null;
    OutputStream out = null;
    try {
        String path = linuxRootPath + "Manual.docx"; // 경로에 접근할 때 역슬래시('\') 사용

        File file = new File(path);
        response.setHeader("Content-Disposition", "attachment;filename=" + file.getName()); 
		// 다운로드 되거나 로컬에 저장되는 용도라는 정보를 알려주는 헤더                                                                                            

        fileInputStream = new FileInputStream(path); // 파일 읽어오기
        out = response.getOutputStream();

        int read = 0;
        byte[] buffer = new byte[1024];
        while ((read = fileInputStream.read(buffer)) != -1) { // 1024바이트씩 계속 읽으면서 outputStream에 저장, -1이 나오면 더이상 읽을
            out.write(buffer, 0, read);
        }
        fileInputStream.close();
        out.close();
    } catch (Exception e) {
        fileInputStream.close();
        out.close();
        throw new Exception("download error");
    } finally {
        fileInputStream.close();
        out.close();
    }
}

 

반응형
반응형
@SuppressWarnings("restriction")
@RequestMapping(value = "/pie", method = RequestMethod.POST)
public @ResponseBody void getServerInfo(HttpServletRequest request, HttpServletResponse response)
        throws IOException {
    OperatingSystemMXBean osBean = (com.sun.management.OperatingSystemMXBean) ManagementFactory
            .getOperatingSystemMXBean();

    double load = 0;

    load = osBean.getSystemCpuLoad();
    File f = new File("/");

    JSONObject systemInfoJson = new JSONObject();

	/** CPU **/
    systemInfoJson.put("cpuUsage", Math.round(load * 100.0)); // 사용량
    systemInfoJson.put("cpuIdle", (100 - Math.round(load * 100.0))); // 남은 용량

	/** HDD **/
    systemInfoJson.put("hddUsage", Math.round((f.getTotalSpace() - f.getUsableSpace()) / (1024 * 1024) / 1000.0)); // 사용량
    systemInfoJson.put("hddIdle", Math.round((f.getFreeSpace()) / (1024 * 1024) / 1000.0)); // 남은 용량

	/** MEMORY **/
    systemInfoJson.put("memoryTotal", Math.round(osBean.getTotalPhysicalMemorySize() / (1024 * 1024) / 1000.0)); // 사용량
    systemInfoJson.put("memoryFree", Math.round(osBean.getFreePhysicalMemorySize() / (1024 * 1024) / 1000.0)); // 남은 용량

    response.setContentType("application/json; charset=UTF-8");
    PrintWriter writer = null;

    writer = response.getWriter();
    writer.print(systemInfoJson);
    writer.flush();

}
반응형