log to console as well as file

This commit is contained in:
Jeffrey Morgan 2023-07-11 15:51:59 -07:00
parent 7226980fb6
commit 3d0a9b477b

View file

@ -13,18 +13,16 @@ require('@electron/remote/main').initialize()
const store = new Store() const store = new Store()
let tray: Tray | null = null let tray: Tray | null = null
const logFile = new winston.transports.File({
filename: path.join(app.getPath('home'), '.ollama', 'logs', 'server.log'),
maxsize: 1024 * 1024 * 20,
maxFiles: 5,
});
const logger = winston.createLogger({ const logger = winston.createLogger({
transports: [logFile], transports: [
format: winston.format.combine( new winston.transports.Console(),
winston.format.timestamp(), new winston.transports.File({
winston.format.printf(info => `${info.timestamp} ${info.level}: ${info.message}`) filename: path.join(app.getPath('home'), '.ollama', 'logs', 'server.log'),
) maxsize: 1024 * 1024 * 20,
maxFiles: 5,
}),
],
format: winston.format.printf(info => `${info.message}`),
}) })
const SingleInstanceLock = app.requestSingleInstanceLock() const SingleInstanceLock = app.requestSingleInstanceLock()
@ -56,25 +54,25 @@ const ollama = path.join(process.resourcesPath, 'ollama')
function server() { function server() {
const binary = app.isPackaged const binary = app.isPackaged
? path.join(process.resourcesPath, 'ollama') ? path.join(process.resourcesPath, 'ollama')
: path.resolve(process.cwd(), '..', 'ollama') : path.resolve(process.cwd(), '..', 'ollama')
const proc = spawn(binary, ['serve']) const proc = spawn(binary, ['serve'], { cwd: path.dirname(binary) })
proc.stdout.on('data', data => { proc.stdout.on('data', data => {
logger.info(`server: ${data.toString()}`) logger.info(`server: ${data.toString()}`)
}) })
proc.stderr.on('data', data => { proc.stderr.on('data', data => {
logger.error(`server: ${data.toString()}`) logger.info(`server: ${data.toString()}`)
}) })
proc.on('exit', () => { proc.on('exit', () => {
logger.info('Restarting the server...'); logger.info('Restarting the server...')
server(); server()
}) })
proc.on('disconnect', () => { proc.on('disconnect', () => {
logger.info('Server disconnected. Reconnecting...'); logger.info('Server disconnected. Reconnecting...')
server(); server()
}) })
process.on('exit', () => { process.on('exit', () => {
@ -82,7 +80,6 @@ function server() {
}) })
} }
function installCLI() { function installCLI() {
const symlinkPath = '/usr/local/bin/ollama' const symlinkPath = '/usr/local/bin/ollama'