Khôi phục lịch sử cam kết Git của bạn: Hướng dẫn từng bước
Tôi đã đặt user.name và user.email của mình không đúng cách, tôi đã phát hiện ra điều này sau một tháng nỗ lực thực hiện một dự án cá nhân. Ngay cả sau khi tôi thực hiện những chỉnh sửa này, rất lâu sau tôi mới phát hiện ra rằng tên tác giả không chính xác vẫn còn đó trong các lần cam kết trước đó của tôi. Tôi đã thử git rebase trong nỗ lực cập nhật biểu đồ đóng góp của mình bằng cách thay đổi các cam kết này.
Nhưng khi làm như vậy, ngày cam kết đã vô tình bị thay đổi, tạo ấn tượng rằng tất cả các cam kết đều được thực hiện cùng một lúc. Sau khi sửa đổi ngoài ý muốn như vậy, hướng dẫn này cố gắng hỗ trợ bạn lấy lại lịch sử cam kết ban đầu để những đóng góp của bạn được phản ánh một cách thích hợp.
Yêu cầu | Sự miêu tả |
---|---|
git reflog | Hiển thị lịch sử của tất cả các sửa đổi kho lưu trữ, bao gồm cả các lần khởi động lại và đặt lại, trong nhật ký tham chiếu. |
git reset --hard | Xóa tất cả các sửa đổi được thực hiện đối với thư mục làm việc và khu vực tổ chức, đồng thời đặt lại nhánh hiện tại theo cam kết đã chọn. |
git push --force | Buộc các thay đổi cục bộ được đẩy tới kho lưu trữ từ xa, xóa mọi xung đột trước đó. |
git filter-branch --env-filter | Áp dụng bộ lọc cho mọi cam kết, viết lại lịch sử Git và cho phép thay đổi các biến môi trường như dữ liệu tác giả và người gửi. |
WRONG_EMAIL="wrong@example.com" | Tạo một biến để theo dõi địa chỉ email sai đã được sử dụng cho các lần xác nhận trước đó. |
CORRECT_NAME="Correct Name" | Thiết lập một biến để cho biết tên nào sẽ được thay đổi trong lịch sử sửa đổi. |
CORRECT_EMAIL="correct@example.com" | Đặt một biến để cho biết địa chỉ email nào sẽ được sử dụng thay cho địa chỉ cũ trong lịch sử cập nhật. |
export GIT_COMMITTER_NAME | Đặt tên người chuyển giao thành giá trị đã cho cho các lần xác nhận được viết lại. |
export GIT_COMMITTER_EMAIL | Đặt email của người gửi thành giá trị đã cho cho các lần xác nhận được viết lại. |
export GIT_AUTHOR_NAME | Sửa đổi tên tác giả thành giá trị đã chọn cho các lần xác nhận được viết lại. |
export GIT_AUTHOR_EMAIL | Sửa đổi email tác giả thành giá trị được chỉ định cho các cam kết được viết lại. |
--tag-name-filter cat | Đảm bảo rằng các thẻ cũng được viết lại bằng bộ lọc đã cho. |
Hiểu việc khôi phục lịch sử Git
The scripts offered are meant to rectify and restore Git's commit history, especially in cases where an inadvertent rebase has changed commit dates. In the first script, the commit hash is found before the rebase process by utilizing . Lệnh này hiển thị lịch sử của tất cả các sửa đổi kho lưu trữ, bao gồm cả việc đặt lại và khởi động lại. Khi xác định vị trí hàm băm xác nhận có liên quan, nhánh được đặt lại về cam kết đó bằng cách sử dụng lệnh, do đó xóa tất cả các sửa đổi tiếp theo. Đây là một bước quan trọng vì nó khôi phục kho lưu trữ về trạng thái trước đó trước khi rebase không chính xác. Các sửa đổi cục bộ sau đó được đẩy tới kho lưu trữ từ xa bằng cách sử dụng lệnh, ghi đè lịch sử trước đó bằng nhánh reset.
Mục đích của tập lệnh thứ hai là cập nhật chi tiết về tác giả cam kết mà không thay đổi ngày cam kết. Với việc sử dụng các lệnh, các biến môi trường như chi tiết tác giả và người gửi có thể được thay đổi trên tất cả các lần xác nhận. Để phát hiện những chi tiết không chính xác và mô tả những chi tiết mới, đúng, các biến như , , Và CORRECT_EMAIL được xác định. Tiếp theo, tập lệnh cập nhật chi tiết người gửi bằng cách sử dụng Và ; tương tự, nó cập nhật chi tiết tác giả bằng cách sử dụng Và export GIT_AUTHOR_EMAIL. tùy chọn đảm bảo rằng các thẻ cũng được viết lại bằng cách sử dụng các bộ lọc nhất định. Tập lệnh này có thể được sử dụng để viết lại lịch sử cam kết với thông tin tác giả chính xác mà không ảnh hưởng đến ngày cam kết ban đầu.
Mang lại lịch sử cam kết ban đầu của Git
Sử dụng lệnh Git
# Step 1: Identify the commit hash before the rebase
git reflog
# Look for the commit hash before the rebase operation
# Step 2: Reset the branch to the commit before the rebase
git reset --hard <commit_hash>
# Step 3: Verify the reset
git log
# Ensure the commit history is back to its original state
# Step 4: Force push the reset history to the remote repository
git push --force
Viết lại cam kết chi tiết về tác giả trong khi giữ nguyên ngày tháng
Sử dụng nhánh bộ lọc Git
# Step 1: Rewrite author information without altering commit dates
git filter-branch --env-filter '
WRONG_EMAIL="wrong@example.com"
CORRECT_NAME="Correct Name"
CORRECT_EMAIL="correct@example.com"
if [ "$GIT_COMMITTER_EMAIL" = "$WRONG_EMAIL" ]
then
export GIT_COMMITTER_NAME="$CORRECT_NAME"
export GIT_COMMITTER_EMAIL="$CORRECT_EMAIL"
fi
if [ "$GIT_AUTHOR_EMAIL" = "$WRONG_EMAIL" ]
then
export GIT_AUTHOR_NAME="$CORRECT_NAME"
export GIT_AUTHOR_EMAIL="$CORRECT_EMAIL"
fi'
--tag-name-filter cat -- --branches --tags
Khôi phục lịch sử bằng Git mà không làm mất dữ liệu
The use of là một yếu tố khác cần tính đến khi làm việc với việc khôi phục lịch sử Git. Bạn có thể áp dụng các sửa đổi được thực hiện bởi các cam kết trước đó cho nhánh hiện tại bằng lệnh này. Khi bạn phải xây dựng lại lịch sử đã bị thay đổi ngoài ý muốn theo cách thủ công, điều này có thể khá hữu ích. Ví dụ: nếu quá trình rebase hoặc thiết lập lại không thành công và bạn muốn thêm lại các thay đổi riêng lẻ, bạn có thể sử dụng để làm như vậy. Kỹ thuật này giữ nguyên lịch sử dự án của bạn bằng cách giữ nguyên ngày và thông báo cam kết ban đầu.
là một lệnh hữu ích bổ sung. Nó hiển thị lịch sử của tất cả các sửa đổi được thực hiện đối với các mẹo của nhánh và các tham chiếu kho lưu trữ khác, ngay cả những sửa đổi thường bị ẩn khỏi chế độ xem trong . Điều này cho phép bạn xác định vị trí các băm cam kết có thể đã bị ghi đè hoặc bị mất trong quá trình đặt lại hoặc khởi động lại không thuận lợi. Sử dụng sự kết hợp của Và git reset --hard, you can revert modifications by restoring your branch to a former state. Furthermore, it's crucial to occasionally take snapshots of the status of your repository using . Thẻ rất hữu ích vì chúng cho phép bạn chú thích những khoảnh khắc lịch sử cụ thể mà có thể hoàn tác trong trường hợp xảy ra sự cố nghiêm trọng.
- Mục đích của việc này là gì ?
- Nó hỗ trợ việc xây dựng lại lịch sử theo cách thủ công bằng cách áp dụng các sửa đổi được thực hiện bởi các cam kết trước đó cho nhánh hiện tại.
- What role does chơi trò bảo tồn quá khứ?
- Nó tạo điều kiện thuận lợi cho việc khôi phục các cam kết bị mất bằng cách hiển thị lịch sử của tất cả các sửa đổi được thực hiện đối với các mẹo và tham chiếu nhánh.
- làm gì nghĩa là?
- Nó xóa tất cả các sửa đổi được thực hiện đối với thư mục làm việc và khu vực tổ chức và đặt lại nhánh hiện tại theo một cam kết nhất định.
- Việc sử dụng các thẻ trong Git là gì?
- Thẻ chụp ảnh nhanh về trạng thái của kho lưu trữ, trạng thái này có thể được khôi phục trong trường hợp xảy ra sự cố nghiêm trọng.
- : Tại sao lại sử dụng nó?
- Để áp dụng các bộ lọc cho quá khứ, thay đổi thông tin chi tiết về tác giả và người thực hiện trên tất cả các lần xác nhận để viết lại lịch sử.
- Điều gì phân biệt một từ một cú đẩy thông thường?
- Bất kể xung đột, nó buộc các thay đổi cục bộ phải thay thế kho lưu trữ từ xa.
- Khi nào thì sử dụng được ?
- Khi bạn cần đặt lại nhánh về một cam kết nhất định và xóa mọi sửa đổi không được cam kết, đây sẽ là phương pháp bạn sử dụng.
- Cần tuân thủ những biện pháp an toàn nào khi sử dụng ?
- Vì lệnh này ghi lại lịch sử và có thể gây mất dữ liệu nếu không sử dụng đúng cách nên hãy đảm bảo bạn sao lưu kho lưu trữ.
- How can a faulty rebase be undone with the aid of ?
- Bằng cách hiển thị mọi thay đổi tham chiếu, bạn có thể xác định vị trí hàm băm xác nhận từ trước rebase và điều chỉnh nhánh một cách thích hợp.
Có thể khó cập nhật thông tin tác giả trong lịch sử Git của bạn mà không thay đổi ngày cam kết, nhưng với các lệnh chính xác, điều đó có thể đạt được. Lịch sử cam kết của bạn được bảo mật khi bạn sử dụng git reflog để xem các trạng thái trong quá khứ và git filter-branch để thay đổi chi tiết tác giả. Để tránh mất dữ liệu, hãy luôn đảm bảo sao lưu kho lưu trữ của bạn trước khi thực hiện các tác vụ đó. Những hành động này sẽ hỗ trợ duy trì tài liệu dự án đáng tin cậy và chính xác.