我错误地在hg repo中添加了一个大文件。然后,我剥离了变更集,但注意到回购大小(.hg文件夹大小)没有减小。我完成了func copy(wc io.WriteCloser, r io.Reader) {
defer wc.Close()
io.Copy(wc, r)
}
func handleConnection(us net.Conn, backend BA.Backend) {
if backend == nil {
log.Printf("no backend available for connection from %s", us.RemoteAddr())
us.Close()
return
}
ip:=us.RemoteAddr().String()
parts:=strings.Split(ip,":")
ip=parts[0]
//w := bufio.NewWriter(us)
//w.WriteString(+"\n")
//w.Flush()
ds, err := net.Dial("tcp", backend.String())
if err != nil {
log.Printf("failed to dial %s: %s", backend, err)
us.Close()
return
}
// Ignore errors
go copy(ds, us)
go copy(us, ds)
}
func tcpBalance(bind string, backends BA.Backends) error {
log.Println("using tcp balancing")
ln, err := net.Listen("tcp", bind)
if err != nil {
return fmt.Errorf("failed to bind: %s", err)
}
log.Printf("listening on %s, balancing %d backends", bind, backends.Len())
for {
conn, err := ln.Accept()
if err != nil {
log.Printf("failed to accept: %s", err)
continue
}
go handleConnection(conn, backends.Choose())
}
return err
}
,但大小确实减小了。因此对我来说有点奏效,但我想了解这个概念。
如果文件已不在历史记录中,将文件保留在存储库中的目的是什么?
我从历史记录中删除文件的方法是否是最佳做法(忘记了我不应该首先添加文件)?
答案 0 :(得分:3)
我怀疑这可能是原因:
剥离变更集时,mercurial将创建一捆变更并将其放置在.hg / strip-backup目录中。这使您可以使用hg unbundle命令恢复更改集。
这可以使.hg的大小保持不变。如果您不打算从该文件中还原文件,则可以将其删除,.hg的大小应反映出这一点。
注意:strip将打印其创建的捆绑文件的名称。您还可以使用--no-backup选项告诉Strip不要创建捆绑文件。