2018. 4. 24.

Spring Schedule :: cron 표현식 정리

Spring Schedule 설정을 위해 시간/주기 등을 설정하는 표현식 입니다. 

하단에 출처 적어 놓았습니다.

cron 표현식
문자열의 좌측부터 우측까지 아래의 순서대로 의미가 있고 각 항목은 space 문자로 구분한다.
 순서
필드명
사용 가능한 값
 1
 seconds
 0~59 , - * /
 2
 minutes
 0~59 , - * /
 3
 hours
 0~23 , - * /
 4
 day of month
 1~31 , - * ? / L W
 5
 month
 1~12 or JAN-DEC , - * /
 6
 day of week
 1-7 or SUN-SAT , - * ? / L #
 7
 years (optional)
 1970~2099 , - * /

특수문자의 의미
 기호
의미 
 사용 예
 *
 모든 수를 의미
seconds에서 사용하면 매초, minutes에서 사용하면 매분, hours에서 사용하면 매시간 
 ?
 해당 항목을 사용하지 않음
day of month에서 사용하면 월중 날짜를 지정하지 않음. day of week에서 사용하면 주중 요일을 지정하지 않음 
 -
 기간을 설정
hours에서 10-12이면 10시, 11시, 12시에 동작
minutes에서 58-59이면 58분, 59분에 동작
 ,
특정 시간을 지정
day of week에서 2,4,6이면 월,수,금에만 동작함
 /
시작시간과 반복 간격 설정
seconds위치에 0/15로 설정하면 0초에 시작해서 15초 간격으로 동작 
minutes위치에 5/10으로 설정하면 5분에 시작해서 10분 간격으로 동작
 L
마지막 기간에 동작
day of month, day of week에서만 사용
day of month에서 사용하면 해당월 마지막 날에 수행
day of week에서 사용하면 토요일에 수행
 W
가장 가까운 평일 동작
day of month에만 사용 
15W로 설정하면 15일이 토요일이면 가장 가까운 14일 금요일에 실행
15W로 설정하고 15일이 일요일이면 16일에 실행
15W로 설정하고 15일이 평일이면 15일에 실행
 LW
L과 W의 조합 
그달의 마지막 평일에 동작 
 #
몇 번째 주와 요일 설정
day of week에 사용 
6#3이면 3 번째 주 금요일에 동작 
4#2이면 2번째 주 수요일에 동작

사용 예
 표현식
의미 
 0 0 12 * * *
매일 12시에 실행 
 0 15 10 * * *
매일 10시 15분에 실행 
 0 * 14 * * *
매일 14시에 0분~59분까지 매분 실행
 0 0/5 14 * * *
매일 14시에 시작해서 5분 간격으로 실행 
 0 0/5 14,18 * * *
매일 14시, 18시에 시작해서 5분 간격으로 실행 
 0 0-5 14 * * *
매일 14시에 0분, 1분, 2분, 3분, 4분, 5분에 실행 
 0 0 20 ? * MON-FRI
월~금일 20시 0분 0초에 실행 
 0 0/5 14 * * ?
아무요일, 매월, 매일 14:00부터 14:05분까지 매분 0초 실행 (6번 실행됨)
 0 15 10 ? * 6L
 매월 마지막 금요일 아무날이나 10:15:00에 실행
 0 15 10 15 * ?
아무요일, 매월 15일 10:15:00에 실행 
 * /1 * * * *
매 1분마다 실행
 * /10 * * * *
매 10분마다 실행 



이전 Task와 Delay 설정
 표현
의미 
 fixed-delay
 이전에 실행된 task의 종료시간으로부터 정의된 시간만큼 지난 후 다음 task를 실행
밀리세컨드 단위
 fixed-rate
 이전에 실행된 task의 시작 시간으로부터 정의된 시간만큼 지난 후 다음 task를 실행
밀리세컨드 단위


2018. 3. 27.

Amcharts excel/Image(png,jpg,svg) 기능 추가하기.

Amcharts의 Export 기능을 사용해 보자.
내보내기 기능을 사용하기 위해선 아래 소스를 적용 시켜야 한다.


<script src="//cdn.amcharts.com/lib/3/plugins/export/export.min.js">
<link href="//cdn.amcharts.com/lib/3/plugins/export/export.css" rel="stylesheet" type="text/css">


아래의 toCSV와 formats.CSV.mimeType을 엑셀이나 다른 형식으로 바꿔주면 CSV 외의 다른 형식으로 내보내기를 할 수 있다. 자세한 사항은 하단 링크를 참조!

    var exportArr = [];
    var chartData = 차트 데이터;

    var temp = {
        label: "temp_title",
        click: function(e,dt) {
            var realData = [], realTitle = "파일명";
            realData = chartData;
            chart.export.toCSV({
                data: realData
            }, function(data) {
                this.download(data, this.defaults.formats.CSV.mimeType, realTitle+".csv");
            });
        }
    }
    exportArr.push(temp);

AmCharts.makeChart( "chartdiv", {
    "export": {
        "enabled": true,
            "exportFields": [
            "logDate",
            "logVal",
        ],
            "columnNames": {
            "logDate": "logDate",
                "logVal": "Value",
        },
        menu:[{
            "class":"export-main",
            menu: [
                {
                    label: "Download CSV",
                    // class: "export-main",
                    menu: exportArr
                }
            ]
        }]
    }
});


참고 링크 - https://github.com/amcharts/export

2017. 11. 30.

JAVA BindingResult(ModelAttribute) 에러 확인하는법

종종 바인딩 값에 대한 에러 확인을 하고 싶을 경우가 발생한다.

그럴 경우 간단하게 아래와 같이 확인 할 수 있다.


public String name(@ModelAttribute vo vo,BindingResult errors) throws Exception {
 if (errors.hasErrors()) {
        System.out.println(":::::::::::::::::: 에러확인 시작 :::::::::::::::::");
        System.out.println(errors.getFieldError());
        System.out.println(":::::::::::::::::: 에러확인 끝 :::::::::::::::::");
 }
}


2017. 11. 28.

제이쿼리 Tabs 사용시 jQueryUI CSS 제거하기


제이쿼리 탭 사용할 경우 jQueryUI를 제거해야할 경우가 발생한다.

아래와 같이 스크립트 적용하면, 해당 CSS를 제거 할 수 있다.

var jQueryUiClass = [".ui-tabs", ".ui-tabs-nav", ".ui-tabs-panel", ".ui-widget", ".ui-widget-header", ".ui-widget-content", ".ui-corner-all", ".ui-corner-top", ".ui-corner-bottom", ".ui-helper-clearfix", ".ui-helper-reset", ".ui-state-default"];

$("#tabs").tabs().each(function(){
   $tabEle = $(this).find( jQueryUiClass.join(", ") ).andSelf();
   $tabEle.removeClass( jQueryUiClass.join(" ").replace(/\./g, "") );
});

2017. 10. 22.

Atom(아톰) Tab space(탭 스페이스) 공백 설정 방법

아톰 : file > Settings > Editor > Tab Length

Tab Length 변경!

아래 이미지 파일을 보시면 쉽게 이해하실 수 있습니다.


2017. 9. 25.

Log4j2.xml 기본 설정 (전자정부프레임워크)

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
29
30
31
32
33
34
35
<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
    <Appenders>
        <Console name="console" target="SYSTEM_OUT">
            <!-- <PatternLayout pattern="%d %5p [%c] %m%n" /> -->
            <PatternLayout pattern="%d %5p (%13F:%L) | %m%n" />
        </Console>
    </Appenders>
    <Loggers>
        <!--특정 로그가 필요한 경우 사용한다.-->
        <!--<Logger name="매퍼네임" level="debug" />-->
 
        <Logger name="egovframework.com.builder" level="debug" additivity="false">
            <AppenderRef ref="console" />
        </Logger>
        <logger name="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" additivity="false">
            <level value="debug" />
            <appender-ref ref="console" />
        </logger>
        <logger name="egovframework.rte.cmmn.ria.support.ExtAnnotationHandlerMapping" additivity="false">
            <level value="debug" />
            <appender-ref ref="console" />
        </logger>
        <logger name="org.springframework.beans.factory.support.DefaultListableBeanFactory" additivity="false">
            <level value="debug" />
            <appender-ref ref="console" />
        </logger>
        
        <Root level="ERROR">
            <AppenderRef ref="console" />
        </Root>
    </Loggers>
 
</Configuration>
 
cs

2017. 1. 4.

Mysql :: 데이터베이스 하위 테이블 모두 삭제


--외래키무시.

SET foreign_key_checks = 0;
SET @tables = NULL;

SELECT GROUP_CONCAT(table_schema, '.', table_name) INTO @tables
FROM information_schema.tables 
WHERE table_schema = '데이터베이스명'; -- specify DB name here.
SET @tables = CONCAT('DROP TABLE ', @tables);
PREPARE stmt FROM @tables;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;


--외래키 다시 허용.

SET foreign_key_checks = 1;