修改脚本制作.so动态库
This commit is contained in:
@@ -43,6 +43,10 @@ go env
|
|||||||
pwd
|
pwd
|
||||||
ls
|
ls
|
||||||
mkdir -p /builds/linxin/rpmbuild/{BUILD,RPMS,SOURCES,SPECS,SRPMS}
|
mkdir -p /builds/linxin/rpmbuild/{BUILD,RPMS,SOURCES,SPECS,SRPMS}
|
||||||
|
cd /builds/linxin/coredump-tools/breakpad/src/tools/linux/coredump_handler_wrapper
|
||||||
|
make
|
||||||
|
mkdir /opt/tsg/coredump/bin
|
||||||
|
cp coredump_handler_wrapper.so /opt/tsg/coredump/bin
|
||||||
mv /builds/linxin/coredump-tools /builds/linxin/coredump-tools-${VERSION_ID}
|
mv /builds/linxin/coredump-tools /builds/linxin/coredump-tools-${VERSION_ID}
|
||||||
tar --warning=no-file-changed -czvf /builds/linxin/rpmbuild/SOURCES/coredump-tools-${VERSION_ID}-${COMMIT_ID}.tar.gz ../coredump-tools-${VERSION_ID}
|
tar --warning=no-file-changed -czvf /builds/linxin/rpmbuild/SOURCES/coredump-tools-${VERSION_ID}-${COMMIT_ID}.tar.gz ../coredump-tools-${VERSION_ID}
|
||||||
cp /builds/linxin/coredump-tools-${VERSION_ID}/script/coredump.spec /builds/linxin/rpmbuild/SPECS
|
cp /builds/linxin/coredump-tools-${VERSION_ID}/script/coredump.spec /builds/linxin/rpmbuild/SPECS
|
||||||
|
|||||||
@@ -1,5 +1,11 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
|
//#cgo CXXFLAGS: -std=c++11
|
||||||
|
// #cgo CFLAGS: -I .
|
||||||
|
// #cgo LDFLAGS: /opt/tsg/coredump/bin/coredump_handler_wrapper.so
|
||||||
|
//#include "coredump_handler_wrapper.h"
|
||||||
|
import "C"
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/zip"
|
"archive/zip"
|
||||||
"context"
|
"context"
|
||||||
@@ -12,7 +18,6 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"math"
|
"math"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
|
||||||
"regexp"
|
"regexp"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
@@ -163,54 +168,43 @@ func writeCoreDumpToFile(config types.Coredump_config) error {
|
|||||||
}
|
}
|
||||||
defer file.Close()
|
defer file.Close()
|
||||||
buf := make([]byte, 1024*1024)
|
buf := make([]byte, 1024*1024)
|
||||||
data := make([]byte, 1024*1024)
|
|
||||||
// create a pipe to write file
|
|
||||||
reader, writer := io.Pipe()
|
|
||||||
go func() {
|
|
||||||
defer writer.Close()
|
|
||||||
// io.Copy(writer, os.Stdin)
|
|
||||||
for {
|
for {
|
||||||
// 从标准输入中读取数据块
|
|
||||||
n, err := os.Stdin.Read(buf)
|
n, err := os.Stdin.Read(buf)
|
||||||
if err != nil {
|
if err != nil && err != io.EOF {
|
||||||
journal.Print(journal.PriErr, err.Error())
|
|
||||||
writer.Close()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
// 将读取的数据块写入到管道中
|
|
||||||
_, err = writer.Write(buf[:n])
|
|
||||||
if err != nil {
|
|
||||||
journal.Print(journal.PriErr, err.Error())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
for {
|
|
||||||
// 从管道中读取数据,直到管道被关闭
|
|
||||||
_, err = io.CopyBuffer(file, reader, data)
|
|
||||||
if err != nil {
|
|
||||||
if err != io.EOF {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
if n == 0 {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
_, err = file.Write(data)
|
_, err = file.Write(buf[:n])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
func HandleCrash(pid int, procfsDir string, mdFilename string) bool {
|
||||||
|
journal.Print(journal.PriInfo, "start convert to minidump")
|
||||||
|
return bool(C.HandleCrash(C.pid_t(pid), C.CString(procfsDir), C.CString(mdFilename)))
|
||||||
|
}
|
||||||
func writeMiniDumpToFile(config types.Coredump_config) error {
|
func writeMiniDumpToFile(config types.Coredump_config) error {
|
||||||
filename := fmt.Sprintf("%s/%s_%s_%d.minidump", config.Storage, config.Initial_ns_pid, config.Process_ns_pid, config.Timestamp)
|
filename := fmt.Sprintf("%s/%s_%s_%d.minidump", config.Storage, config.Initial_ns_pid, config.Process_ns_pid, config.Timestamp)
|
||||||
cmd := exec.Command("/opt/tsg/coredump/bin/core_handler", config.Initial_ns_pid, filename)
|
pid, err := strconv.Atoi(config.Initial_ns_pid)
|
||||||
cmd.Stdin = os.Stdin
|
|
||||||
output, err := cmd.Output()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
fmt.Println(string(output))
|
flag := HandleCrash(pid, "/proc/"+config.Initial_ns_pid, filename)
|
||||||
|
if !flag {
|
||||||
|
return errors.New("can not convert to minidump")
|
||||||
|
}
|
||||||
|
journal.Print(journal.PriInfo, "end convert to minidump")
|
||||||
|
// cmd := exec.Command("/opt/tsg/coredump/bin/core_handler", config.Initial_ns_pid, filename)
|
||||||
|
// cmd.Stdin = os.Stdin
|
||||||
|
// output, err := cmd.Output()
|
||||||
|
// if err != nil {
|
||||||
|
// return err
|
||||||
|
// }
|
||||||
|
// fmt.Println(string(output))
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
func compress(config types.Coredump_config) error {
|
func compress(config types.Coredump_config) error {
|
||||||
|
|||||||
20
coredump-handler/coredump_handler_wrapper.h
Normal file
20
coredump-handler/coredump_handler_wrapper.h
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
#ifndef CORE_HANDLER_H_
|
||||||
|
#define CORE_HANDLER_H_
|
||||||
|
|
||||||
|
#include <pwd.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <syslog.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
_Bool HandleCrash(pid_t pid, const char* procfs_dir, const char* md_filename);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // CORE_HANDLER_H_
|
||||||
@@ -31,9 +31,8 @@ mkdir -p %{buildroot}/opt/tsg/coredump/etc
|
|||||||
mkdir -p %{buildroot}/etc/profile.d
|
mkdir -p %{buildroot}/etc/profile.d
|
||||||
mkdir -p %{buildroot}/usr/lib/tmpfiles.d
|
mkdir -p %{buildroot}/usr/lib/tmpfiles.d
|
||||||
mkdir -p %{buildroot}/usr/lib/sysctl.d
|
mkdir -p %{buildroot}/usr/lib/sysctl.d
|
||||||
|
cp /builds/linxin/coredump-tools/breakpad/src/tools/linux/coredump_handler_wrapper/coredump_handler_wrapper.so %{buildroot}/opt/tsg/coredump/bin
|
||||||
cp ./coredump-handler/coredump-handler %{buildroot}/opt/tsg/coredump/bin
|
cp ./coredump-handler/coredump-handler %{buildroot}/opt/tsg/coredump/bin
|
||||||
chmod +x ./coredump-handler/core_handler
|
|
||||||
cp ./coredump-handler/core_handler %{buildroot}/opt/tsg/coredump/bin
|
|
||||||
cp ./config/config.json %{buildroot}/opt/tsg/coredump/etc
|
cp ./config/config.json %{buildroot}/opt/tsg/coredump/etc
|
||||||
cp ./coredump-tool/coredump-tool %{buildroot}/opt/tsg/coredump/bin
|
cp ./coredump-tool/coredump-tool %{buildroot}/opt/tsg/coredump/bin
|
||||||
cp ./script/coredump-tools.sh %{buildroot}/etc/profile.d
|
cp ./script/coredump-tools.sh %{buildroot}/etc/profile.d
|
||||||
@@ -44,7 +43,7 @@ cp ./60-coredump.conf %{buildroot}/usr/lib/sysctl.d
|
|||||||
/opt/tsg/coredump/etc/config.json
|
/opt/tsg/coredump/etc/config.json
|
||||||
/opt/tsg/coredump/bin/coredump-handler
|
/opt/tsg/coredump/bin/coredump-handler
|
||||||
/opt/tsg/coredump/bin/coredump-tool
|
/opt/tsg/coredump/bin/coredump-tool
|
||||||
/opt/tsg/coredump/bin/core_handler
|
/opt/tsg/coredump/bin/coredump_handler_wrapper.so
|
||||||
/etc/profile.d/coredump-tools.sh
|
/etc/profile.d/coredump-tools.sh
|
||||||
/usr/lib/tmpfiles.d/coredump.conf
|
/usr/lib/tmpfiles.d/coredump.conf
|
||||||
/usr/lib/sysctl.d/60-coredump.conf
|
/usr/lib/sysctl.d/60-coredump.conf
|
||||||
|
|||||||
Reference in New Issue
Block a user